2 |
|
# |
3 |
|
# Interface |
4 |
|
# --------- |
5 |
< |
# new(ConfigArea) : A new BuildSetup |
5 |
> |
# new(toolbox) : A new BuildSetup |
6 |
|
# BuildSetup(directory,targets) : prepare the ground for a build and build |
7 |
|
# getclass(directory) : return (Class, ClassDir, BuildFileobject) |
8 |
|
# associated with directory |
9 |
< |
# setup(dir) |
9 |
> |
# |
10 |
|
|
11 |
|
package BuildSystem::BuildSetup; |
12 |
|
require 5.004; |
20 |
|
my $class=shift; |
21 |
|
my $self={}; |
22 |
|
bless $self,$class; |
23 |
< |
$self->{area}=shift; |
24 |
< |
$self->{toolbox}=$self->{area}->toolbox(); |
25 |
< |
$self->{projconfigdir}=$self->{area}->configurationdir(); |
26 |
< |
$self->{localtop}=$self->{area}->location(); |
27 |
< |
$self->{buildfilename}="BuildFile"; |
28 |
< |
$self->_configurationsetup(); |
23 |
> |
$self->{toolbox}=shift; |
24 |
|
return $self; |
25 |
|
} |
26 |
|
|
27 |
< |
sub _generateexternals { |
28 |
< |
my $self=shift; |
29 |
< |
my $outfile=shift; |
30 |
< |
|
31 |
< |
# -- specifiy these files for dependency information |
32 |
< |
my $depfile=$self->{projconfigdir}."/External_Dependencies"; |
33 |
< |
|
34 |
< |
# -- get list of dependent files |
35 |
< |
my $datadir=$self->{localtop}."/.SCRAM/".$ENV{SCRAM_ARCH}; |
36 |
< |
$fdir=FileHandle->new(); |
37 |
< |
opendir $fdir, $datadir; |
38 |
< |
my @depfiles=grep !/^\.\.?$/, readdir $fdir; |
39 |
< |
undef $fdir; |
40 |
< |
for (my $i=0; $i<=$#depfiles; $i++ ) { |
41 |
< |
$depfiles[$i]=$datadir."/".$depfiles[$i]; |
42 |
< |
} |
43 |
< |
|
44 |
< |
# -- do we need to rebuild? |
45 |
< |
if ( SCRAMUtils::dated($outfile,@depfiles) ) { |
46 |
< |
print "Configuring Local Area\n"; |
47 |
< |
# -- open output file |
48 |
< |
my $fout=FileHandle->new(); |
49 |
< |
$fout->open(">".$outfile) or die "Unable to open $outfile for output". |
50 |
< |
$!."\n"; |
51 |
< |
|
52 |
< |
# -- print out tool/ version info |
53 |
< |
my ($tool,$toolobj,$f,$val,$version); |
54 |
< |
foreach $tool ( $self->{toolbox}->tools() ) { |
55 |
< |
$version=$self->{toolbox}->defaultversion($tool); |
56 |
< |
# default versions |
57 |
< |
print $fout "ifdef $tool\n".$tool."_V_".$version."=true\nendif\n"; |
58 |
< |
# -- set up the different version -- externals |
59 |
< |
foreach $version ( $self->{toolbox}->versions($tool) ) { |
60 |
< |
$toolobj=$self->{toolbox}->gettool($tool,$version); |
61 |
< |
@deps=$toolobj->getfeature("_externals"); |
62 |
< |
foreach $d ( @deps ) { |
63 |
< |
$d=~tr[A-Z][a-z]; |
64 |
< |
print $fout "ifdef ".$tool."_V_".$version."\n $d=true\nendif\n"; |
65 |
< |
} |
66 |
< |
# -- tool info |
67 |
< |
print $fout "ifdef ".$tool."_V_".$version."\n"; |
68 |
< |
foreach $f ( $toolobj->features() ) { |
69 |
< |
foreach $val ( $toolobj->getfeature($f) ) { |
70 |
< |
print $fout "\t".$f." += ".$val."\n"; |
71 |
< |
} |
72 |
< |
} |
73 |
< |
print $fout "endif\n"; |
27 |
> |
sub _generateexternals |
28 |
> |
############################################################### |
29 |
> |
# _generateexternals # |
30 |
> |
############################################################### |
31 |
> |
# modified : Thu Jul 12 12:06:50 2001 / SFA # |
32 |
> |
# params : # |
33 |
> |
# : # |
34 |
> |
# : # |
35 |
> |
# : # |
36 |
> |
# function : # |
37 |
> |
# : # |
38 |
> |
# : # |
39 |
> |
############################################################### |
40 |
> |
{ |
41 |
> |
my $self=shift; |
42 |
> |
my $outfile=shift; |
43 |
> |
|
44 |
> |
# -- specifiy these files for dependency information |
45 |
> |
# NB: This file is never used! |
46 |
> |
|
47 |
> |
my $depfile=$ENV{projconfigdir}."/External_Dependencies"; |
48 |
> |
|
49 |
> |
# -- get list of dependent files |
50 |
> |
my $datadir=$ENV{LOCALTOP}."/.SCRAM/".$ENV{SCRAM_ARCH}; |
51 |
> |
$fdir=FileHandle->new(); |
52 |
> |
opendir $fdir, $datadir; |
53 |
> |
my @depfiles=grep !/^\.\.?$/, readdir $fdir; |
54 |
> |
undef $fdir; |
55 |
> |
|
56 |
> |
for (my $i=0; $i<=$#depfiles; $i++ ) |
57 |
> |
{ |
58 |
> |
$depfiles[$i]=$datadir."/".$depfiles[$i]; |
59 |
> |
} |
60 |
> |
|
61 |
> |
# -- do we need to rebuild? |
62 |
> |
if ( SCRAMUtils::dated($outfile,@depfiles) ) |
63 |
> |
{ |
64 |
> |
print "Configuring Local Area\n"; |
65 |
> |
# -- open output file |
66 |
> |
my $fout=FileHandle->new(); |
67 |
> |
$fout->open(">".$outfile) or die "Unable to open $outfile for output". |
68 |
> |
$!."\n"; |
69 |
> |
|
70 |
> |
# -- print out tool/ version info |
71 |
> |
my ($tool,$toolobj,$f,$val,$version); |
72 |
> |
|
73 |
> |
foreach $tool ( $self->{toolbox}->tools() ) |
74 |
> |
{ |
75 |
> |
$version=$self->{toolbox}->defaultversion($tool); |
76 |
> |
|
77 |
> |
# default versions |
78 |
> |
print $fout "ifdef $tool\n".$tool."_V_".$version."=true\nendif\n"; |
79 |
> |
|
80 |
> |
# -- set up the different version -- externals |
81 |
> |
foreach $version ( $self->{toolbox}->versions($tool) ) |
82 |
> |
{ |
83 |
> |
$toolobj=$self->{toolbox}->gettool($tool,$version); |
84 |
> |
@deps=$toolobj->getfeature("_externals"); |
85 |
> |
# |
86 |
> |
foreach $d ( @deps ) |
87 |
> |
{ |
88 |
> |
$d=~tr[A-Z][a-z]; |
89 |
> |
print $fout "ifdef ".$tool."_V_".$version."\n $d=true\nendif\n"; |
90 |
> |
} |
91 |
> |
# -- tool info |
92 |
> |
print $fout "ifdef ".$tool."_V_".$version."\n"; |
93 |
> |
|
94 |
> |
foreach $f ( $toolobj->features() ) |
95 |
> |
{ |
96 |
> |
foreach $val ( $toolobj->getfeature($f) ) |
97 |
> |
{ |
98 |
> |
print $fout "\t".$f." += ".$val."\n"; |
99 |
> |
} |
100 |
> |
} |
101 |
> |
# -- include any makefiles associated with the tool |
102 |
> |
if ( -f $self->{toolbox}->toolmakefile($tool,$version) ) |
103 |
> |
{ |
104 |
> |
print $fout "-include ". |
105 |
> |
$self->{toolbox}->toolmakefile($tool,$version)."\n"; |
106 |
> |
} |
107 |
> |
print $fout "endif\n"; |
108 |
|
} |
109 |
< |
} |
110 |
< |
# some addittional processing of specific vars |
111 |
< |
print $fout 'INCLUDEPATH+=$(addprefix -I,$(INCLUDE))'."\n"; |
112 |
< |
print $fout 'LDFLAGS+=$(addprefix -L,$(LIBDIR))'."\n"; |
113 |
< |
print $fout 'CPPFLAGS+=$(addprefix -D,$(CPPDEFINES))'."\n"; |
114 |
< |
print $fout 'lib+=$(extralib)'."\n"; |
115 |
< |
print $fout 'LDLIBS+=$(addprefix -l,$(lib))'."\n"; |
116 |
< |
print $fout 'LDLIBS+=$(addprefix -l,$(REQUIRES))'."\n"; |
117 |
< |
|
118 |
< |
undef $fout; |
119 |
< |
$self->verbose("End Configuration Setup"); |
120 |
< |
} |
121 |
< |
} |
93 |
< |
|
94 |
< |
sub classsetup { |
95 |
< |
my $self=shift; |
96 |
< |
my $THISDIR=shift; |
97 |
< |
|
98 |
< |
my $classmakefile; |
99 |
< |
|
100 |
< |
my ($Class, $ClassDir, $bf)=$self->getclass($THISDIR); |
101 |
< |
$self->verbose("Class = $Class : ClassDir = $ClassDir for directory ". |
102 |
< |
$THISDIR); |
103 |
< |
|
104 |
< |
# -- should we ignore? |
105 |
< |
if ( $bf->ignore() ) { |
106 |
< |
print "Nothing to be done - empty group\n"; |
107 |
< |
exit; |
108 |
< |
} |
109 |
< |
|
110 |
< |
|
111 |
< |
# -- Create a makefile from the class BuildFile |
112 |
< |
my $classbuildfile=$self->{localtop}."/". |
113 |
< |
$self->{projconfigdir}."/".$Class."_BuildFile"; |
114 |
< |
if ( -f $classbuildfile ) { |
115 |
< |
$classmakefile=$self->{localtop}."/".$ENV{INTwork}. |
116 |
< |
"/".$Class."_makefile.mk"; |
117 |
< |
if ( SCRAMUtils::dated($classmakefile, $classbuildfile) ) { |
118 |
< |
# -- generate the new makefile if out of date |
119 |
< |
$self->verbose("Generating $classmakefile from". |
120 |
< |
" $classbuildfile"); |
121 |
< |
my $classbf=BuildSystem::BuildFile->new($self->{area}); |
122 |
< |
undef $ENV{LatestBuildFile}; # gets set by BuildFile |
123 |
< |
$classbf->GenerateMakefile($classbuildfile, $classmakefile); |
124 |
< |
undef $ENV{LatestBuildFile}; # we dont want this included in the |
125 |
< |
# hierarchy |
126 |
< |
} |
127 |
< |
} |
128 |
< |
else { |
129 |
< |
# -- No BuildFile - maybe its old style makefile |
130 |
< |
$classmakefile=$self->{localtop}."/". |
131 |
< |
$self->{projconfigdir}."/".$Class."_makefile.mk"; |
132 |
< |
if ( ! -f $classmakefile ) { |
133 |
< |
$self->error("Unable to find matching ".$Class. |
134 |
< |
"_BuildFile or ".$Class."_makefile.mk"); |
135 |
< |
} |
136 |
< |
} |
137 |
< |
# -- set LatestBuildFile |
138 |
< |
if ( $bf->buildfile() ne "" ) { |
139 |
< |
$ENV{LatestBuildFile}=$bf->makefile(); |
140 |
< |
} |
141 |
< |
else { |
142 |
< |
$ENV{LatestBuildFile}=$self->{topbf}->makefile(); |
143 |
< |
} |
144 |
< |
|
145 |
< |
return ($Class,$ClassDir,$classmakefile); |
146 |
< |
} |
147 |
< |
|
148 |
< |
sub _configurationsetup { |
149 |
< |
my $self=shift; |
150 |
< |
|
151 |
< |
# -- set working directory |
152 |
< |
$self->{workdir}=$ENV{INTwork}; |
153 |
< |
$self->{fullworkdir}=$self->{localtop}."/".$self->{workdir}; |
154 |
< |
|
155 |
< |
# -- make working directory |
156 |
< |
chdir $self->{localtop}; |
157 |
< |
AddDir::adddir($self->{workdir}); |
158 |
< |
|
159 |
< |
# -- generate tool info |
160 |
< |
$self->_generateexternals($self->{fullworkdir}."/clientmakefile"); |
161 |
< |
|
162 |
< |
# -- process project BuildFile |
163 |
< |
$self->_topbuildfile(); |
164 |
< |
} |
109 |
> |
} |
110 |
> |
# some addittional processing of specific vars |
111 |
> |
print $fout 'INCLUDEPATH+=$(addprefix -I,$(INCLUDE))'."\n"; |
112 |
> |
print $fout 'LDFLAGS+=$(addprefix -L,$(LIBDIR))'."\n"; |
113 |
> |
print $fout 'CPPFLAGS+=$(addprefix -D,$(CPPDEFINES))'."\n"; |
114 |
> |
print $fout 'lib+=$(extralib)'."\n"; |
115 |
> |
print $fout 'LDLIBS+=$(addprefix -l,$(lib))'."\n"; |
116 |
> |
print $fout 'LDLIBS+=$(addprefix -l,$(REQUIRES))'."\n"; |
117 |
> |
print $fout 'LD_LIBRARY_PATH:=$(subst $(space),:,$(LD_LIBRARY_PATH))'."\n"; |
118 |
> |
|
119 |
> |
undef $fout; |
120 |
> |
} |
121 |
> |
} |
122 |
|
|
123 |
< |
sub BuildDir { |
124 |
< |
my $self=shift; |
125 |
< |
my $THISDIR=shift; |
126 |
< |
my @Targets=@_; |
127 |
< |
my $DefaultBuildFile=""; |
128 |
< |
|
129 |
< |
# -- Create working directory |
130 |
< |
my $workdir=$self->{workdir}."/".$THISDIR; |
131 |
< |
chdir $self->{localtop}; |
132 |
< |
AddDir::adddir($workdir); |
133 |
< |
$ENV{workdir}=$workdir; |
134 |
< |
my $fullworkdir=$self->{localtop}."/".$ENV{workdir}; |
135 |
< |
chdir $fullworkdir || die "Unable to enter working directory $!"; |
136 |
< |
|
137 |
< |
# -- setup Class specifics |
138 |
< |
($Class,$ClassDir,$classmakefile)=$self->classsetup($THISDIR); |
139 |
< |
$ENV{classmakefile}=$classmakefile; |
140 |
< |
$ENV{Class}=$Class; |
141 |
< |
$ENV{ClassDir}=$ClassDir; |
142 |
< |
$DefaultBuildFile=$ENV{classmakefile}; |
143 |
< |
$ENV{DefaultBuildFile}=$DefaultBuildFile; |
123 |
> |
sub BuildSetup |
124 |
> |
{ |
125 |
> |
############################################################### |
126 |
> |
# BuildSetup # |
127 |
> |
############################################################### |
128 |
> |
# modified : Fri Aug 10 16:57:03 2001 / SFA # |
129 |
> |
# params : # |
130 |
> |
# : # |
131 |
> |
# : # |
132 |
> |
# : # |
133 |
> |
# function : Build targets. # |
134 |
> |
# : # |
135 |
> |
# : # |
136 |
> |
############################################################### |
137 |
> |
my $self=shift; |
138 |
> |
my $THISDIR=shift; |
139 |
> |
my @Targets=@_; |
140 |
> |
my $DefaultBuildFile=""; |
141 |
> |
my $Class=""; |
142 |
> |
|
143 |
> |
# -- Create working directory |
144 |
> |
chdir $ENV{LOCALTOP}; |
145 |
> |
AddDir::adddir($ENV{INTwork}."/".$THISDIR); |
146 |
> |
|
147 |
> |
my ($Class, $ClassDir, $bf)=$self->getclass($THISDIR); |
148 |
> |
$self->verbose("Class = $Class"); |
149 |
> |
$self->verbose("ClassDir = $ClassDir"); |
150 |
|
|
151 |
+ |
if ( $bf->ignore() ) |
152 |
+ |
{ |
153 |
+ |
print "Nothing to be done - empty group\n"; |
154 |
+ |
exit; |
155 |
+ |
} |
156 |
+ |
shift; |
157 |
+ |
$self->_generateexternals($ENV{LOCALTOP}."/".$ENV{INTwork}."/clientmakefile"); |
158 |
+ |
|
159 |
+ |
# set up the workdir variable |
160 |
+ |
$ENV{workdir}=$ENV{INTwork}."/".$ClassDir; |
161 |
+ |
my $fullworkdir=$ENV{LOCALTOP}."/".$ENV{workdir}; |
162 |
+ |
|
163 |
+ |
# set up projdeps variable |
164 |
+ |
my $projectfile=$ENV{projconfigdir}."/External_Dependencies"; |
165 |
+ |
if ( -e $ENV{LOCALTOP}."/".$projectfile ) |
166 |
+ |
{ |
167 |
+ |
$ENV{projdeps}=$ENV{LOCALTOP}."/".$projectfile; |
168 |
+ |
} |
169 |
+ |
elsif ( -e $ENV{RELEASETOP}."/".$projectfile ) |
170 |
+ |
{ |
171 |
+ |
$ENV{projectfile}=$ENV{RELEASETOP}."/".$projectfile; |
172 |
+ |
} |
173 |
+ |
if ( $DefaultBuildFile eq "" ) |
174 |
+ |
{ |
175 |
+ |
# Map Relevant makefile classmakefile directory |
176 |
+ |
my $classmakefile=$ENV{projconfigdir}."/".$Class."_makefile.mk"; |
177 |
+ |
if ( -e $ENV{LOCALTOP}."/".$classmakefile ) |
178 |
+ |
{ |
179 |
+ |
$ENV{classmakefile}=$ENV{LOCALTOP}."/".$classmakefile; |
180 |
+ |
} |
181 |
+ |
elsif ( -e $ENV{RELEASETOP}."/".$classmakefile ) |
182 |
+ |
{ |
183 |
+ |
$ENV{classmakefile}=$ENV{RELEASETOP}."/".$classmakefile; |
184 |
+ |
} |
185 |
+ |
else |
186 |
+ |
{ |
187 |
+ |
print "\nUnable to locate $classmakefile\n"; |
188 |
+ |
print " Not in $ENV{LOCALTOP}\n"; |
189 |
+ |
print " Not in $ENV{RELEASETOP}\n"; |
190 |
+ |
exit 1; |
191 |
+ |
} |
192 |
+ |
$DefaultBuildFile=$ENV{classmakefile}; # TODO - only for override |
193 |
+ |
} |
194 |
+ |
|
195 |
+ |
$ENV{ClassDir}=$ClassDir; |
196 |
+ |
$ENV{Class}=$Class; |
197 |
+ |
$ENV{DefaultBuildFile}=$DefaultBuildFile; |
198 |
+ |
|
199 |
+ |
chdir $fullworkdir || die "Unable to enter working directory $!"; |
200 |
+ |
|
201 |
+ |
# Set up some other useful variables fo the Build |
202 |
+ |
# list of directories available |
203 |
+ |
opendir IDR, "$ENV{LOCALTOP}/$THISDIR"; |
204 |
+ |
@allfiles= grep !/^\.\.?$/, readdir IDR; |
205 |
+ |
foreach $file ( @allfiles ) |
206 |
+ |
{ |
207 |
+ |
if ( -d "$ENV{LOCALTOP}/$THISDIR/$file" ) |
208 |
+ |
{ # only add if its a directory |
209 |
+ |
$ENV{SCRAM_AVAILDIRS}=$ENV{SCRAM_AVAILDIRS}." ".$file; |
210 |
+ |
} |
211 |
+ |
else |
212 |
+ |
{ |
213 |
+ |
$ENV{SCRAM_AVAILFILES}=$ENV{SCRAM_AVAILFILES}." ".$file; |
214 |
+ |
} |
215 |
+ |
} |
216 |
+ |
$targetnumber=$#Targets; |
217 |
|
|
218 |
< |
# -- Set up some other useful variables for the Build |
219 |
< |
# set variables listing directories/files available |
220 |
< |
my $fh=FileHandle->new(); |
221 |
< |
opendir $fh, "$self->{localtop}/$THISDIR"; |
222 |
< |
my @allfiles= grep !/^\.\.?$/, readdir $fh; |
223 |
< |
undef $fh; |
224 |
< |
foreach $file ( @allfiles ) { |
225 |
< |
if ( -d "$self->{localtop}/$THISDIR/$file" ) { |
226 |
< |
$ENV{SCRAM_AVAILDIRS}=$ENV{SCRAM_AVAILDIRS}." ".$file; |
227 |
< |
} |
228 |
< |
else { |
229 |
< |
$ENV{SCRAM_AVAILFILES}=$ENV{SCRAM_AVAILFILES}." ".$file; |
230 |
< |
} |
231 |
< |
} |
232 |
< |
my $targetnumber=$#Targets; |
204 |
< |
$ENV{"MAKETARGETS"}=""; |
205 |
< |
foreach $word ( @Targets ) { |
206 |
< |
if ( $word=~/.*=.*/ ) { # if we have an assignment it cant be a target |
207 |
< |
$targetnumber--; |
208 |
< |
} |
209 |
< |
else { |
210 |
< |
# set some variables for use in makefiles |
211 |
< |
$ENV{"MAKETARGET_".$word}=$word; |
212 |
< |
if ( $ENV{"MAKETARGETS"} ne "" ) { |
213 |
< |
$ENV{"MAKETARGETS"}=$ENV{"MAKETARGETS"}." ".$word; |
214 |
< |
} |
215 |
< |
else { |
216 |
< |
$ENV{"MAKETARGETS"}=$word; |
217 |
< |
} |
218 |
< |
} |
219 |
< |
} |
218 |
> |
foreach $word ( @Targets ) |
219 |
> |
{ |
220 |
> |
if ( $word=~/.*=.*/ ) |
221 |
> |
{ # if we have an assignment it cant be a target |
222 |
> |
$targetnumber--; |
223 |
> |
} |
224 |
> |
elsif ( $word=~/^-/ ) |
225 |
> |
{ |
226 |
> |
$targetnumber--; |
227 |
> |
} |
228 |
> |
else |
229 |
> |
{ |
230 |
> |
$ENV{"MAKETARGET_".$word}=$word; |
231 |
> |
} |
232 |
> |
} |
233 |
|
|
234 |
< |
# -- If target not specified default to the class name target |
235 |
< |
if ( $targetnumber == -1 ) { |
236 |
< |
push @Targets,$Class; |
237 |
< |
} |
234 |
> |
# If not specified default to the class name target |
235 |
> |
if ( $targetnumber == -1 ) |
236 |
> |
{ |
237 |
> |
push @Targets,$Class; |
238 |
> |
} |
239 |
|
|
240 |
< |
$ENV{DefaultMakefile}="$ENV{TOOL_HOME}/basics.mk"; |
240 |
> |
$ENV{DefaultMakefile}="$ENV{TOOL_HOME}/basics.mk"; |
241 |
|
|
242 |
< |
$SCRAM_GROUPSDIR=$self->{localtop}."/".$self->{projconfigdir}."/groups.mk"; |
243 |
< |
if ( -f $SCRAM_GROUPSDIR ) { |
242 |
> |
$SCRAM_GROUPSDIR=$ENV{LOCALTOP}."/".$ENV{projconfigdir}."/groups.mk"; |
243 |
> |
if ( -f $SCRAM_GROUPSDIR ) |
244 |
> |
{ |
245 |
|
$ENV{SCRAM_GROUPSDIR}=$SCRAM_GROUPSDIR; |
246 |
< |
} |
246 |
> |
} |
247 |
> |
|
248 |
> |
# Do a datestamp check so that make will build files that have changed |
249 |
> |
# rather than just those which are older than their dependencies |
250 |
> |
# The main build here |
251 |
> |
|
252 |
> |
$rv=system("gmake","--no-print-directory","-r","-k","-f","$ENV{DefaultMakefile}","-I$ENV{TOOL_HOME}",datestamp_config); |
253 |
> |
|
254 |
> |
# Be verbose: |
255 |
> |
$self->verbose(">> Going to use ".$ENV{DefaultMakefile}." as the default makefile"); |
256 |
> |
|
257 |
> |
my $gmakejobsflag = "-j"; |
258 |
> |
# Temporarily hard-code ncpu as 1: |
259 |
> |
my $ncpu = 1; |
260 |
|
|
261 |
< |
# Do a datestamp check so that make will build files that have changed |
262 |
< |
# rather than just those which are older than their dependencies |
263 |
< |
# The main build here |
264 |
< |
$rv=system("gmake","--no-print-directory","-r","-k","-f","$ENV{DefaultMakefile}","-I$ENV{TOOL_HOME}",datestamp_config); |
237 |
< |
$rv=system("gmake","--no-print-directory","-r","-k","-f","$ENV{DefaultMakefile}","-I$ENV{TOOL_HOME}",datestamp, @Targets); |
238 |
< |
return $rv/256; # return the exit status of gmake |
239 |
< |
} |
261 |
> |
$rv=system("gmake","--no-print-directory","$gmakejobsflag","$ncpu","-r","-k","-f","$ENV{DefaultMakefile}","-I$ENV{TOOL_HOME}",datestamp, @Targets); |
262 |
> |
|
263 |
> |
return $rv/256; # return the exit status of gmake |
264 |
> |
} |
265 |
|
|
266 |
|
sub getclass { |
267 |
|
my $self=shift; |
269 |
|
my $Class="DEFAULT"; |
270 |
|
my $ClassDir=""; |
271 |
|
|
247 |
– |
#return if $dirname eq ""; |
272 |
|
@DIRA=split /\//, $dirname; |
273 |
|
|
274 |
< |
my $thispath="."; |
275 |
< |
# -- construct all class buildfiles in the path |
274 |
> |
$thispath="."; |
275 |
> |
# bootstrap from project buildfile if it exists |
276 |
> |
my $bf=BuildSystem::BuildFile->new($self->{toolbox}); |
277 |
> |
$bf->CheckBuildFile($ENV{projconfigdir}); |
278 |
> |
|
279 |
> |
my @ClassPaths=split /:/, $bf->BlockClassPath(); |
280 |
> |
foreach $BClassPath ( @ClassPaths ) { |
281 |
> |
next if ( $BClassPath eq ""); |
282 |
> |
push @LoBCA, [ split /\//, $BClassPath ]; |
283 |
> |
} |
284 |
|
for ( $i=0; $i<=$#DIRA; $i++ ) { |
285 |
< |
#$thispath=(($thispath eq "")?$DIRA[$i]:$thispath."/".$DIRA[$i]); |
286 |
< |
$thispath=$thispath."/".$DIRA[$i]; |
287 |
< |
if ( ! exists $self->{pathbf}{$thispath} ) { |
256 |
< |
$self->verbose("Initialising BuildFile in $thispath"); |
257 |
< |
$self->{pathbf}{$thispath}=$self->_startbuildfile($thispath); |
258 |
< |
} |
259 |
< |
# -- check class overriden by BuildFile |
260 |
< |
if ( defined $self->{pathbf}{$thispath}->classname() ) { |
261 |
< |
$Class=$self->{pathbf}{$thispath}->classname(); |
285 |
> |
$thispath=$thispath."/".$DIRA[$i]; |
286 |
> |
if ( ($ClassName=$bf->CheckBuildFile($thispath)) ne "" ) { |
287 |
> |
$Class=$ClassName; |
288 |
|
$ClassDir=$thispath; |
289 |
|
} |
290 |
+ |
# TODO --- Must test against position of last new BlockCaseA |
291 |
+ |
# Need to reset array LoBCA to the New BlockPath |
292 |
+ |
# - merge and replace options |
293 |
+ |
# |
294 |
|
else { |
295 |
< |
# -- sort it out from classpath directives |
296 |
< |
foreach $BlockClassA ( @{$self->{LoBCA}} ) { |
297 |
< |
foreach $elem ( @$BlockClassA ) { |
268 |
< |
if ( $elem=~/^$DIRA[$i]\+/ ) { |
269 |
< |
$elem=~s/^$DIRA[$i]//; |
295 |
> |
foreach $BlockClassA ( @LoBCA ) { |
296 |
> |
if ( $$BlockClassA[0]=~/^$DIRA[$i]\+/ ) { |
297 |
> |
$$BlockClassA[0]=~s/^$DIRA[$i]//; |
298 |
|
} |
299 |
< |
if ( $elem=~/^\+/ ) { |
300 |
< |
($Class=$elem)=~s/^\+//; |
299 |
> |
if ( $$BlockClassA[0]=~/^\+/ ) { |
300 |
> |
($Class=$$BlockClassA[0])=~s/^\+//; |
301 |
|
$ClassDir=$thispath; |
302 |
+ |
shift @$BlockClassA; |
303 |
+ |
} |
304 |
+ |
else { |
305 |
+ |
@$BlockClassA=(); |
306 |
|
} |
307 |
|
} |
276 |
– |
} |
308 |
|
} |
309 |
|
} |
310 |
< |
# -- default case |
311 |
< |
if ( $ClassDir eq "" ) { |
281 |
< |
if ( ! defined $self->{pathbf}{'.'}) { |
282 |
< |
$self->{pathbf}{'.'}=$self->_startbuildfile("."); |
283 |
< |
$self->verbose("DEFAULT class initialised : ".$self->{pathbf}{'.'}); |
284 |
< |
} |
285 |
< |
$ClassDir="."; |
286 |
< |
} |
287 |
< |
|
288 |
< |
# -- retunrs |
289 |
< |
($ClassDir_c=$ClassDir)=~s/^\.\///; |
290 |
< |
return ( $Class, $ClassDir_c, $self->{pathbf}{$ClassDir}); |
291 |
< |
} |
292 |
< |
|
293 |
< |
# |
294 |
< |
# Check to see if the buildfile is local or in the release area and |
295 |
< |
# parse appropriately |
296 |
< |
# |
297 |
< |
sub _startbuildfile { |
298 |
< |
my $self=shift; |
299 |
< |
my $classdir=shift; |
300 |
< |
|
301 |
< |
my $bf=BuildSystem::BuildFile->new($self->{area}); |
302 |
< |
my $thisfile="$classdir/$self->{buildfilename}"; |
303 |
< |
|
304 |
< |
if ( -e $self->{localtop}."/".$thisfile ) { |
305 |
< |
$bf->buildfile($self->{localtop}."/".$thisfile); |
306 |
< |
$bf->ParseBuildFile($self->{localtop}, $classdir, |
307 |
< |
$self->{buildfilename}); |
308 |
< |
} |
309 |
< |
elsif ( -e $ENV{RELEASETOP}."/".$thisfile ) { |
310 |
< |
$bf->buildfile("$ENV{RELEASETOP}/$thisfile"); |
311 |
< |
$bf->ParseBuildFile($ENV{RELEASETOP}, $classdir, |
312 |
< |
$slef->{buildfilename}); |
313 |
< |
} |
314 |
< |
return $bf; |
315 |
< |
} |
316 |
< |
|
317 |
< |
sub _topbuildfile { |
318 |
< |
my $self=shift; |
319 |
< |
|
320 |
< |
# -- Analyse project buildfile if it exists |
321 |
< |
$self->{topbf}=BuildSystem::BuildFile->new($self->{area}); |
322 |
< |
|
323 |
< |
$self->{topbf}->buildfile($self->{localtop}."/".$self->{projconfigdir} |
324 |
< |
."/".$self->{buildfilename}); |
325 |
< |
# -- generate top level makefile |
326 |
< |
$self->verbose("Generating Top Level BuildFile"); |
327 |
< |
$self->{topbf}->ParseBuildFile($self->{localtop}, |
328 |
< |
$self->{projconfigdir},$self->{buildfilename}); |
329 |
< |
|
330 |
< |
my @ClassPaths=split /:/, $self->{topbf}->BlockClassPath(); |
331 |
< |
foreach $BClassPath ( @ClassPaths ) { |
332 |
< |
next if ( $BClassPath eq ""); |
333 |
< |
push @{$self->{LoBCA}}, [ split /\//, $BClassPath ]; |
334 |
< |
} |
335 |
< |
|
310 |
> |
$ClassDir=~s/^\.\///; |
311 |
> |
return ( $Class, $ClassDir, $bf); |
312 |
|
} |