ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/COMP/SCRAM/src/BuildSystem/BuildSetup.pm
(Generate patch)

Comparing COMP/SCRAM/src/BuildSystem/BuildSetup.pm (file contents):
Revision 1.6 by williamc, Tue Sep 19 10:09:30 2000 UTC vs.
Revision 1.24 by sashby, Tue May 14 10:21:19 2002 UTC

# Line 2 | Line 2
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;
# Line 20 | Line 20 | sub new {
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 >                  if ( $f eq 'LIBDIR'  ||  $f eq 'INCLUDE' )
99 >                     {
100 >                     # Remove duplications:
101 >                     print $fout "\t".$f." := \$(filter-out ".$val.",\$(".$f."))","\n";
102 >                     print $fout "\t".$f." += ".$val."\n";
103 >                     }
104 >                  else
105 >                     {
106 >                     print $fout "\t".$f." += ".$val."\n";
107 >                     }
108 >                  }
109 >               }
110 >            # -- include any makefiles associated with the tool
111 >            if ( -f $self->{toolbox}->toolmakefile($tool,$version) )
112 >               {
113 >               print $fout "-include ".
114 >                  $self->{toolbox}->toolmakefile($tool,$version)."\n";
115 >               }
116 >            print $fout "endif\n";
117              }
118 <          }
119 <          # some addittional processing of specific vars
120 <          print $fout 'INCLUDEPATH+=$(addprefix -I,$(INCLUDE))'."\n";
121 <          print $fout 'LDFLAGS+=$(addprefix -L,$(LIBDIR))'."\n";
122 <          print $fout 'CPPFLAGS+=$(addprefix -D,$(CPPDEFINES))'."\n";
123 <          print $fout 'lib+=$(extralib)'."\n";
124 <          print $fout 'LDLIBS+=$(addprefix -l,$(lib))'."\n";
125 <          print $fout 'LDLIBS+=$(addprefix -l,$(REQUIRES))'."\n";
126 <
127 <          undef $fout;
128 <          $self->verbose("End Configuration Setup");
91 <        }
92 < }
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");
118 >         }
119 >      # some addittional processing of specific vars
120 >      print $fout 'INCLUDEPATH+=$(addprefix -I,$(INCLUDE))'."\n";
121 >      print $fout 'LDFLAGS+=$(addprefix -L,$(LIBDIR))'."\n";
122 >      print $fout 'CPPFLAGS+=$(addprefix -D,$(CPPDEFINES))'."\n";
123 >      print $fout 'lib+=$(extralib)'."\n";
124 >      # Hack to parse the lib list and remove duplicates:
125 >      print $fout 'ORDEREDLIB=$(shell $(SCRAMPERL) $(TOOL_HOME)/ProcessLibs $(lib))',"\n";
126 >      print $fout 'LDLIBS+=$(addprefix -l,$(ORDEREDLIB))'."\n";
127 >      print $fout 'LDLIBS+=$(addprefix -l,$(REQUIRES))'."\n";
128 >      print $fout 'LD_LIBRARY_PATH:=$(subst $(space),:,$(LD_LIBRARY_PATH))'."\n";
129  
130 <        # -- process project BuildFile
131 <        $self->_topbuildfile();
132 < }
130 >      undef $fout;
131 >      }
132 >   }
133  
134 < sub BuildDir {
135 <        my $self=shift;
136 <        my $THISDIR=shift;
137 <        my @Targets=@_;
138 <        my $DefaultBuildFile="";
139 <
140 <        # -- Create working directory
141 <        my $workdir=$self->{workdir}."/".$THISDIR;
142 <        chdir $self->{localtop};
143 <        AddDir::adddir($workdir);
144 <        $ENV{workdir}=$workdir;
145 <        my $fullworkdir=$self->{localtop}."/".$ENV{workdir};
146 <        chdir $fullworkdir || die "Unable to enter working directory $!";
147 <
148 <        # -- setup Class specifics
149 <        ($Class,$ClassDir,$classmakefile)=$self->classsetup($THISDIR);
150 <        $ENV{classmakefile}=$classmakefile;
151 <        $ENV{Class}=$Class;
152 <        $ENV{ClassDir}=$ClassDir;
153 <        $DefaultBuildFile=$ENV{classmakefile};
154 <        $ENV{DefaultBuildFile}=$DefaultBuildFile;
134 > sub BuildSetup
135 >   {
136 >   ###############################################################
137 >   # BuildSetup                                                  #
138 >   ###############################################################
139 >   # modified : Fri Aug 10 16:57:03 2001 / SFA                   #
140 >   # params   :                                                  #
141 >   #          :                                                  #
142 >   #          :                                                  #
143 >   #          :                                                  #
144 >   # function : Build targets.                                   #
145 >   #          :                                                  #
146 >   #          :                                                  #
147 >   ###############################################################
148 >   my $self=shift;
149 >   my $THISDIR=shift;
150 >   my @Targets=@_;
151 >   my $DefaultBuildFile="";
152 >   my $Class="";
153 >
154 >   # -- Create working directory
155 >   chdir $ENV{LOCALTOP};
156 >   AddDir::adddir($ENV{INTwork}."/".$THISDIR);
157 >
158 >   my ($Class, $ClassDir, $bf)=$self->getclass($THISDIR);
159 >   $self->verbose("Class = $Class");
160 >   $self->verbose("ClassDir = $ClassDir");
161          
162 +   if ( $bf->ignore() )
163 +      {
164 +      print "Nothing to be done - empty group\n";
165 +      exit;
166 +      }
167 +   shift;
168 +   $self->_generateexternals($ENV{LOCALTOP}."/".$ENV{INTwork}."/clientmakefile");
169 +
170 +   # set up the workdir variable
171 +   $ENV{workdir}=$ENV{INTwork}."/".$ClassDir;
172 +   my $fullworkdir=$ENV{LOCALTOP}."/".$ENV{workdir};
173 +  
174 +   # set up projdeps variable
175 +   my $projectfile=$ENV{projconfigdir}."/External_Dependencies";
176 +   if ( -e $ENV{LOCALTOP}."/".$projectfile )
177 +      {
178 +      $ENV{projdeps}=$ENV{LOCALTOP}."/".$projectfile;
179 +      }
180 +   elsif ( -e $ENV{RELEASETOP}."/".$projectfile )
181 +      {
182 +      $ENV{projectfile}=$ENV{RELEASETOP}."/".$projectfile;
183 +      }
184 +   if ( $DefaultBuildFile eq "" )
185 +      {
186 +      # Map Relevant makefile classmakefile directory
187 +      my $classmakefile=$ENV{projconfigdir}."/".$Class."_makefile.mk";
188 +      if ( -e $ENV{LOCALTOP}."/".$classmakefile )
189 +         {
190 +         $ENV{classmakefile}=$ENV{LOCALTOP}."/".$classmakefile;
191 +         }
192 +      elsif ( -e $ENV{RELEASETOP}."/".$classmakefile )
193 +         {
194 +         $ENV{classmakefile}=$ENV{RELEASETOP}."/".$classmakefile;
195 +         }
196 +      else
197 +         {
198 +         print "\nUnable to locate $classmakefile\n";
199 +         print " Not in $ENV{LOCALTOP}\n";
200 +         print " Not in $ENV{RELEASETOP}\n";
201 +         exit 1;
202 +         }
203 +      $DefaultBuildFile=$ENV{classmakefile}; # TODO - only for override
204 +      }
205 +  
206 +   $ENV{ClassDir}=$ClassDir;
207 +   $ENV{Class}=$Class;
208 +   $ENV{DefaultBuildFile}=$DefaultBuildFile;
209 +  
210 +   chdir $fullworkdir || die "Unable to enter working directory $!";
211 +
212 +   # Set up some other useful variables fo the Build
213 +   # list of directories available
214 +   opendir IDR, "$ENV{LOCALTOP}/$THISDIR";
215 +   @allfiles= grep !/^\.\.?$/, readdir IDR;
216 +   foreach $file ( @allfiles )
217 +      {
218 +      if ( -d "$ENV{LOCALTOP}/$THISDIR/$file" )
219 +         { # only add if its a directory
220 +         $ENV{SCRAM_AVAILDIRS}=$ENV{SCRAM_AVAILDIRS}." ".$file;
221 +         }
222 +      else
223 +         {
224 +         $ENV{SCRAM_AVAILFILES}=$ENV{SCRAM_AVAILFILES}." ".$file;
225 +         }
226 +      }
227 +   $targetnumber=$#Targets;
228  
229 <        # -- Set up some other useful variables for the Build
230 <        # set variables listing directories/files available
231 <        my $fh=FileHandle->new();
232 <        opendir $fh, "$self->{localtop}/$THISDIR";
233 <        my @allfiles= grep !/^\.\.?$/, readdir $fh;
234 <        undef $fh;
235 <        foreach $file ( @allfiles ) {
236 <         if ( -d "$self->{localtop}/$THISDIR/$file" ) {
237 <           $ENV{SCRAM_AVAILDIRS}=$ENV{SCRAM_AVAILDIRS}." ".$file;
238 <         }
239 <         else {
240 <           $ENV{SCRAM_AVAILFILES}=$ENV{SCRAM_AVAILFILES}." ".$file;
241 <         }
242 <        }
243 <        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 <        }
229 >   foreach $word ( @Targets )
230 >      {
231 >      if ( $word=~/.*=.*/ )
232 >         { # if we have an assignment it cant be a target
233 >         $targetnumber--;
234 >         }
235 >      elsif ( $word=~/^-/ )
236 >         {
237 >         $targetnumber--;
238 >         }
239 >      else
240 >         {
241 >         $ENV{"MAKETARGET_".$word}=$word;
242 >         }
243 >      }
244  
245 <       # -- If target not specified default to the class name target
246 <       if ( $targetnumber == -1 ) {
247 <        push @Targets,$Class;
248 <       }
245 >   # If not specified default to the class name target
246 >   if ( $targetnumber == -1 )
247 >      {
248 >      push @Targets,$Class;
249 >      }
250  
251 <    $ENV{DefaultMakefile}="$ENV{TOOL_HOME}/basics.mk";
251 >   $ENV{DefaultMakefile}="$ENV{TOOL_HOME}/basics.mk";
252  
253 <    $SCRAM_GROUPSDIR=$self->{localtop}."/".$self->{projconfigdir}."/groups.mk";
254 <    if ( -f $SCRAM_GROUPSDIR ) {
253 >   $SCRAM_GROUPSDIR=$ENV{LOCALTOP}."/".$ENV{projconfigdir}."/groups.mk";
254 >   if ( -f $SCRAM_GROUPSDIR )
255 >      {
256        $ENV{SCRAM_GROUPSDIR}=$SCRAM_GROUPSDIR;
257 <    }
257 >      }
258 >  
259 >   # Do a datestamp check so that make will build files that have changed
260 >   # rather than just those which are older than their dependencies
261 >   # The main build here
262 >
263 >   $rv=system("gmake","--no-print-directory","-r","-k","-f","$ENV{DefaultMakefile}","-I$ENV{TOOL_HOME}",datestamp_config);
264 >
265 >   # Be verbose:
266 >   $self->verbose(">> Going to use ".$ENV{DefaultMakefile}." as the default makefile");
267 >  
268 >   my $gmakejobsflag = "-j";
269 >   # Temporarily hard-code ncpu as 1:
270 >   my $ncpu = 1;
271  
272 <    # Do a datestamp check so that make will build files that have changed
273 <    # rather than just those which are older than their dependencies
274 <    # The main build here
275 <    $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 < }
272 >   $rv=system("gmake","--no-print-directory","$gmakejobsflag","$ncpu","-r","-k","-f","$ENV{DefaultMakefile}","-I$ENV{TOOL_HOME}",datestamp, @Targets);
273 >
274 >   return $rv/256; # return the exit status of gmake
275 >   }
276  
277   sub getclass {
278      my $self=shift;
# Line 244 | Line 280 | sub getclass {
280      my $Class="DEFAULT";
281      my $ClassDir="";
282          
247    #return if $dirname eq "";
283      @DIRA=split /\//, $dirname;
284  
285 <    my $thispath=".";
286 <    # -- construct all class buildfiles in the path
285 >    $thispath=".";
286 >    # bootstrap from project buildfile if it exists
287 >    my $bf=BuildSystem::BuildFile->new($self->{toolbox});
288 >    $bf->CheckBuildFile($ENV{projconfigdir});
289 >
290 >    my @ClassPaths=split /:/, $bf->BlockClassPath();
291 >    foreach $BClassPath ( @ClassPaths ) {
292 >      next if ( $BClassPath eq "");
293 >      push @LoBCA, [ split /\//, $BClassPath ];
294 >    }
295      for ( $i=0; $i<=$#DIRA; $i++ ) {
296 <        #$thispath=(($thispath eq "")?$DIRA[$i]:$thispath."/".$DIRA[$i]);
297 <        $thispath=$thispath."/".$DIRA[$i];
298 <        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();
296 >        $thispath=$thispath."/".$DIRA[$i];
297 >        if ( ($ClassName=$bf->CheckBuildFile($thispath)) ne "" ) {
298 >                $Class=$ClassName;
299                  $ClassDir=$thispath;
300          }
301 +        # TODO --- Must test against position of last new BlockCaseA
302 +        # Need to reset array LoBCA to the New BlockPath
303 +        # - merge and replace options
304 +        #
305          else {
306 <          # -- sort it out from classpath directives
307 <          foreach $BlockClassA ( @{$self->{LoBCA}} ) {
308 <           foreach $elem ( @$BlockClassA ) {
268 <            if ( $elem=~/^$DIRA[$i]\+/ ) {
269 <                $elem=~s/^$DIRA[$i]//;
306 >          foreach $BlockClassA ( @LoBCA ) {
307 >            if ( $$BlockClassA[0]=~/^$DIRA[$i]\+/ ) {
308 >                $$BlockClassA[0]=~s/^$DIRA[$i]//;
309              }
310 <            if ( $elem=~/^\+/ ) {
311 <                ($Class=$elem)=~s/^\+//;
310 >            if ( $$BlockClassA[0]=~/^\+/ ) {
311 >                ($Class=$$BlockClassA[0])=~s/^\+//;
312                  $ClassDir=$thispath;
313 +                shift @$BlockClassA;
314 +            }
315 +            else {
316 +                @$BlockClassA=();
317              }
318            }
276         }
319          }
320      }
321 <    # -- default case
322 <    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 <
321 >    $ClassDir=~s/^\.\///;
322 >    return ( $Class, $ClassDir, $bf);
323   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines