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

Comparing COMP/SCRAM/src/BuildSystem/BuildFile.pm (file contents):
Revision 1.24 by sashby, Wed Nov 6 17:31:04 2002 UTC vs.
Revision 1.37 by muzaffar, Thu Apr 26 07:55:35 2012 UTC

# Line 1 | Line 1
1 < # BuildFile
1 > #____________________________________________________________________
2 > # File: BuildFile.pm
3 > #____________________________________________________________________
4 > #  
5 > # Author: Shaun Ashby <Shaun.Ashby@cern.ch>
6 > # Copyright: 2003 (C) Shaun Ashby
7   #
8 < # Interface
4 < # ---------
5 < # new(toolbox)
6 < # ParseBuildFile($base,$path,$file)
7 < # ParseBuildFileExport(filename)
8 < # BlockClassPath() : Return the class path
9 < # ignore()      : return 1 if directory should be ignored 0 otherwise
10 <
8 > #--------------------------------------------------------------------
9   package BuildSystem::BuildFile;
12 use Utilities::Verbose;
13 use ActiveDoc::SimpleDoc;
14 use BuildSystem::ToolBox;
10   require 5.004;
11 < @ISA=qw(Utilities::Verbose);
11 > use Exporter;
12 > use ActiveDoc::SimpleDoc;
13  
14 < BEGIN {
15 < $buildfile="BuildFile";
16 < }
17 <
18 < sub new {
19 <        my $class=shift;
20 <        my $self={};
21 <        bless $self, $class;
22 <        $self->{toolbox}=shift;
23 <        $self->{Arch}=1;
24 <        push @{$self->{ARCHBLOCK}}, $self->{Arch};
25 <        return $self;
26 < }
27 <
28 < sub ignore {
29 <        my $self=shift;
30 <        $self->verbose(">> ignore......<<");
31 <        
32 <        return (defined $self->{ignore})?$self->{ignore}:0;
33 < }
34 <
35 < sub _initswitcher {
36 <        my $self=shift;
37 <        my $switch=ActiveDoc::SimpleDoc->new();
42 <        my $parse="makebuild";
43 <        $self->verbose(">> _initswitcher: <<");
44 <        $switch->newparse($parse);
45 <        $switch->addignoretags($parse);
46 <        $self->_commontags($switch,$parse);
47 <        $switch->addtag($parse,"Build", \&Build_start, $self);
48 <        $switch->addtag($parse,"none",
49 <                                        \&OutToMakefile,$self,
50 <                                        \&OutToMakefile, $self,
51 <                                        "", $self);
52 <        $switch->addtag($parse,"Bin",
53 <                                        \&Bin_start,$self,
54 <                                        \&OutToScreen, $self,
55 <                                        "", $self);
56 <        $switch->addtag($parse,"Module",
57 <                                        \&Module_start,$self,
58 <                                        \&OutToScreen, $self,
59 <                                        "", $self);
60 <
61 <        $switch->addtag($parse,"ProductStore",
62 <                                        \&Store_start,$self,
63 <                                        "", $self,
64 <                                        "", $self);
65 <        $switch->addtag($parse,"LibType",
66 <                                        \&LibType_Start,$self,
67 <                                        \&LibType_text, $self,
68 <                                        \&LibType_end,$self);
69 <        $switch->addtag($parse,"ConfigurationClass",
70 <                                        \&Class_StartTag,$self,
71 <                                        \&OutToMakefile, $self,
72 <                                        "", $self);
73 <        $switch->addtag($parse,"ClassPath",
74 <                                        \&setBlockClassPath,$self,
75 <                                        \&OutToMakefile, $self,
76 <                                        "", $self);
77 <        $switch->addtag($parse,"AssociateGroup",
78 <                                        "",$self,
79 <                                        \&AssociateGroup,$self,
80 <                                        "", $self);
81 <        $switch->addtag($parse,"Environment",
82 <                                        \&Environment_start,$self,
83 <                                        \&OutToMakefile, $self,
84 <                                        \&Environment_end,$self);
85 <        $switch->addtag($parse,"Export",
86 <                                        \&export_start,$self,
87 <                                        \&OutToMakefile, $self,
88 <                                        \&export_end,$self);
89 <        return $switch;
90 < }
14 > @ISA=qw(Exporter);
15 > @EXPORT_OK=qw( );
16 > #
17 > sub new()
18 >   ###############################################################
19 >   # new                                                         #
20 >   ###############################################################
21 >   # modified : Wed Dec  3 19:03:22 2003 / SFA                   #
22 >   # params   :                                                  #
23 >   #          :                                                  #
24 >   # function :                                                  #
25 >   #          :                                                  #
26 >   ###############################################################
27 >   {
28 >   my $proto=shift;
29 >   my $class=ref($proto) || $proto;
30 >   $self={};
31 >   bless $self,$class;
32 >   $self->{DEPENDENCIES} = {};
33 >   $self->{content} = {};
34 >   $self->{scramdoc}=ActiveDoc::SimpleDoc->new();
35 >   $self->{scramdoc}->newparse("builder",__PACKAGE__,'Subs',shift);
36 >   return $self;
37 >   }
38  
39 < sub _commontags
39 > sub parse()
40     {
41     my $self=shift;
42 <   my $switch=shift;
43 <   my $parse=shift;
44 <  
45 <   $self->verbose(">> _commontags: SW ".$switch." PARSE ".$parse." <<");
46 <  
47 <   $switch->grouptag("Export",$parse);
48 <   $switch->addtag($parse,"Use",
49 <                   \&Use_start,$self,
50 <                   \&OutToMakefile, $self,
51 <                   "", $self);
52 <   $switch->addtag($parse,"Group",
53 <                   \&Group_start,$self,
54 <                   \&OutToMakefile, $self,
55 <                   "", $self);
56 <   $switch->grouptag("Group",$parse);
57 <   $switch->addtag($parse,"External",
58 <                   \&External_StartTag,$self,
59 <                   \&OutToMakefile, $self,
60 <                   "", $self);
61 <   $switch->addtag($parse,"lib",
62 <                   \&lib_start,$self,
63 <                   \&OutToMakefile, $self,"", $self);
64 <   $switch->addtag($parse,"debuglib",
65 <                   \&debuglib_start,$self,
66 <                   \&OutToMakefile, $self,
67 <                   "", $self);
68 <   $switch->addtag($parse,"Architecture",
69 <                   \&Arch_Start,$self,
70 <                   \&OutToMakefile, $self,
71 <                   \&Arch_End,$self);
72 <   $switch->addtag($parse,"INCLUDE_PATH",
73 <                   \&IncludePath_Start,$self,
74 <                   \&OutToMakefile, $self,
75 <                   "",$self);
76 <   $switch->addtag($parse,"CompilerMap",
77 <                   \&CompilerMap_Start,$self,
78 <                   \&OutToMakefile, $self,
79 <                   "",$self);
80 <   return $switch;
81 <   }
82 <
136 < sub ParseBuildFile {
137 <        my $self=shift;
138 <        my $base=shift;
139 <        my $path=shift;
140 <        my $filename=shift @_;
141 <        my $fullfilename;
142 <        if ( $filename!~/^\// ) {
143 <         $fullfilename="$base/$path/$filename";
144 <        }
145 <        else {
146 <         $fullfilename=$filename;
147 <        }
148 <
149 <        $self->verbose(">> ParseBuildFile: FN ".$fullfilename." <<");
150 <        
151 <        $self->{path}=$path;
152 <        $numbins=0;
153 <        $self->{envnum}=0;
154 <        $self->{envlevel}=0;
155 <        $self->{currentenv}="$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/".
156 <                                                                "BuildFile.mk";
157 <        $self->{switch}=$self->_initswitcher();
158 <        $self->{switch}->filetoparse($fullfilename);
159 <
160 <        # open a temporary gnumakefile to store output.
161 <        use Utilities::AddDir;
162 <        AddDir::adddir("$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}");
163 <        my $fh=FileHandle->new();
164 <        open ( $fh, ">$ENV{LOCALTOP}/$ENV{INTwork}/".$self->{path}."/BuildFile.mk"
165 <          ) or die "Unable to open /$ENV{INTwork}/".$self->{path}."/BuildFile.mk $!\n";
166 <        @{$self->{filehandlestack}}=($fh);
167 <        # make an alias
168 <        *GNUmakefile=$fh;
169 <        if ( -e $ENV{LatestBuildFile} ) {
170 <          print GNUmakefile "include $ENV{LatestBuildFile}\n";
171 <        }
172 <
173 <        $ENV{LatestBuildFile}="$ENV{LOCALTOP}/$ENV{INTwork}/".$self->{path}."/BuildFile.mk";
174 <        $self->{switch}->parse("makebuild"); # sort out supported tags
175 <        if ( $numbins > 0 ) {
176 <         print GNUmakefile <<ENDTEXT;
177 < ifndef BINMODE
178 < help::
179 < \t\@echo Generic Binary targets
180 < \t\@echo ----------------------
181 < endif
182 < ENDTEXT
183 <         foreach $target ( keys %$targettypes ) {
184 <         print GNUmakefile <<ENDTEXT;
185 < ifndef BINMODE
186 < help::
187 < \t\@echo $target
188 < endif
189 < ENDTEXT
190 <         }
191 <        }
192 <        close GNUmakefile;
193 < }
194 <
195 < sub ParseBuildFile_Export {
196 <        my $self=shift;
197 <        my $filename=shift;
198 <
199 <        $self->verbose(">> ParseBuildFile_Export: FN ".$filename." <<");
200 <        
201 <        my $bf=BuildSystem::BuildFile->new($self->{toolbox});
202 <        if ( defined $self->{remoteproject} ) {
203 <           $bf->{remoteproject}=$self->{remoteproject};
204 <        }
205 <        $bf->_parseexport($filename);
206 <        undef $bf;
207 < }
208 <
209 < sub _location {
210 <        my $self=shift;
211 <        use File::Basename;
212 <        $self->verbose(">> _location: <<");
213 <        return dirname($self->{switch}->filetoparse());
214 < }
215 <
216 < sub _parseexport {
217 <        my $self=shift;
218 <        my $filename=shift;
219 <        $self->verbose(">> _parseexport: FN ".$filename." <<");
220 <        
221 <        my $switchex=ActiveDoc::SimpleDoc->new();
222 <        $switchex->filetoparse($filename);
223 <        $switchex->newparse("export");
224 <        $switchex->addignoretags("export");
225 <        $switchex->addtag("export","Export",
226 <                                        \&export_start_export,$self,
227 <                                        \&OutToMakefile, $self,
228 <                                        \&export_end_export,$self);
229 <        $self->_commontags($switchex,"export");
230 <        $switchex->allowgroup("__export","export");
231 <        $self->{switch}=$switchex;
232 <        $switchex->parse("export"); # sort out supported tags
233 < }
234 <
235 < sub _pushremoteproject {
236 <        my $self=shift;
237 <        my $path=shift;
238 <
239 <        $self->verbose(">> _pushremoteproject: PATH ".$path." <<");
240 <        
241 <        if ( defined $self->{remoteproject} ) {
242 <          push @{$self->{rpstack}}, $self->{remoteproject};
243 <        }
244 <        $self->{remoteproject}=$path;
245 < }
246 <
247 < sub _popremoteproject {
248 <        my $self=shift;
249 <        $self->verbose(">> _popremoteproject:  <<");
250 <        
251 <        if ( $#{$self->{rpstack}} >=0 ) {
252 <          $self->{remoteproject}=pop @{$self->{rpstack}};
253 <        }
254 <        else {
255 <          undef $self->{remoteproject};
256 <        }
257 < }
258 <
259 < sub _toolmapper {
260 <        my $self=shift;
261 <
262 <        if ( ! defined $self->{mapper} ) {
263 <           require BuildSystem::ToolMapper;
264 <           $self->{mapper}=BuildSystem::ToolMapper->new();
265 <        }
266 <        $self->verbose(">> _toolmapper: TM ".$self->{mapper}."<<");
267 <        return $self->{mapper};
268 < }
269 <
270 <
271 < # ---- Tag routines
272 <
273 < #-- Override a class type with the <ConfigurationClass type=xxx> tag
274 < #   the type tag will pick up a pre-defined class type from project space.
275 <
276 < sub Class_StartTag {
277 <        my $self=shift;
278 <        my $name=shift;
279 <        my $hashref=shift;
280 <
281 <        $self->verbose(">> Classs_StartTag: NM ".$name." <<");
282 <        
283 <        if ( $self->{Arch} ) {
284 <         if ( defined $$hashref{'type'} ) {
285 <                $ClassName=$$hashref{'type'};
286 <         }
287 <        }
288 < }
289 <
290 < sub IncludePath_Start
42 >   my ($filename)=@_;
43 >   my $fhead='<?xml version="1.0" encoding="UTF-8" standalone="yes"?><doc type="BuildSystem::BuildFile" version="1.0">';
44 >   my $ftail='</doc>';
45 >   $self->{scramdoc}->filetoparse($filename);
46 >   $self->{archs}=[];
47 >   $self->{archflag}=1;
48 >   $self->{scramdoc}->parse("builder",$fhead,$ftail);
49 >   # We're done with the SimpleDoc object so delete it:
50 >   delete $self->{scramdoc};
51 >   delete $self->{archs};
52 >   delete $self->{archflag};
53 >   }
54 >
55 > sub classpath()
56 >   {
57 >   my ($object,$name,%attributes)=@_;
58 >   # The getter part:
59 >   if (ref($object) eq __PACKAGE__)
60 >      {
61 >      return $self->{content}->{CLASSPATH};
62 >      }
63 >   if (!$self->{archflag}){return;}
64 >   $self->{nested} == 1 ? push(@{$self->{tagcontent}->{CLASSPATH}}, $attributes{'path'})
65 >      : push(@{$self->{content}->{CLASSPATH}}, $attributes{'path'});
66 >   }
67 >
68 > sub productstore()
69 >   {
70 >   my ($object,$name,%attributes)=@_;
71 >   # The getter part:
72 >   if (ref($object) eq __PACKAGE__)
73 >      {
74 >      # Return an array of ProductStore hashes:
75 >      return $self->{content}->{PRODUCTSTORE};
76 >      }
77 >   if (!$self->{archflag}){return;}
78 >   $self->{nested} == 1 ? push(@{$self->{tagcontent}->{PRODUCTSTORE}}, \%attributes)
79 >      : push(@{$self->{content}->{PRODUCTSTORE}}, \%attributes) ;
80 >   }
81 >
82 > sub include()
83     {
84     my $self=shift;
85 <   my $name=shift;
86 <   my $hashref=shift;
87 <  
88 <   $self->verbose(">> IncludePath_Start: NM ".$name." <<");
89 <  
90 <   $self->{switch}->checktag( $name, $hashref, 'path');
91 <   if ( $self->{Arch} )
85 >   # Return an array of required includes:
86 >   return $self->{content}->{INCLUDE};
87 >   }
88 >
89 > sub include_path()
90 >   {
91 >   my ($object,$name,%attributes)=@_;
92 >   if (!$self->{archflag}){return;}
93 >   $self->{nested} == 1 ? push(@{$self->{tagcontent}->{INCLUDE}}, $attributes{'path'})
94 >      : push(@{$self->{content}->{INCLUDE}}, $attributes{'path'});
95 >   }
96 >
97 > sub use()
98 >   {
99 >   my $object=shift;
100 >   # The getter part:
101 >   if (ref($object) eq __PACKAGE__)
102        {
103 <      print GNUmakefile "INCLUDE+=".$self->_location()."/".$$hashref{'path'}."\n";
103 >      # Add or return uses (package deps):
104 >      @_ ? push(@{$self->{content}->{USE}},@_)
105 >         : @{$self->{content}->{USE}};
106 >      }
107 >   else
108 >      {
109 >      if (!$self->{archflag}){return;}
110 >      my ($name,%attributes)=@_;
111 >      $self->{DEPENDENCIES}->{$attributes{'name'}} = 1;
112 >      $self->{nested} == 1 ? push(@{$self->{tagcontent}->{USE}}, $attributes{'name'})
113 >         : push(@{$self->{content}->{USE}}, $attributes{'name'});
114        }
115     }
116  
117 < #
118 < # generic build tag
119 < #
120 < sub Build_start {
121 <        my $self=shift;
122 <        my $name=shift;
123 <        my $hashref=shift;
124 <
313 <        $self->verbose(">> Build_start: NM ".$name." <<");
314 <        
315 <        $self->{switch}->checktag($name,$hashref,'class');
316 <        if ( $self->{Arch} ) {
317 <
318 <          # -- determine the build products name
319 <          my $name;
320 <          if ( exists $$hashref{'name'} ) {
321 <            $name=$$hashref{'name'};
322 <          }
323 <          else {
324 <            $self->{switch}->parseerror("No name specified for build product");
325 <          }
326 <
327 <          # -- check we have a lookup for the class type
328 <          my $mapper=$self->_toolmapper();
329 <          if ( ! $mapper->exists($$hashref{'class'}) ) {
330 <            $self->{switch}->parseerror("Unknown class : ".$$hashref{'class'});
331 <          }
332 <          else {
333 <           my @types=$self->_toolmapper()->types($$hashref{'class'});
334 <           my @deftypes=$self->_toolmapper()->defaulttypes($$hashref{'class'});
335 <
336 <           my $fh=$self->{filehandlestack}[0];
337 <           my @targets=();
338 <
339 <           # -- generate generic targets
340 <           print $fh "ifndef _BuildLink_\n";
341 <           print $fh "# -- Generic targets\n";
342 <           push @targets, $$hashref{'class'};
343 <           foreach $dtype ( @deftypes ) {
344 <            print $fh $$hashref{'class'}."::".$$hashref{'class'}."_".
345 <                                                                $dtype."\n";
346 <           }
347 <           print $fh "\n";
348 <
349 <           # -- generate targets for each type
350 <           foreach $type ( @types ) {
351 <
352 <            # -- generic name for each type
353 <            my $pattern=$$hashref{'class'}."_".$type;
354 <            my $dirname=$$hashref{'class'}."_".$type."_".$name;
355 <            print $fh "# ------ $pattern rules ---------------\n";
356 <            print $fh $$hashref{'class'}."_".$type."::".$$hashref{'class'}.
357 <                                                        "_".$type."_$name\n\n";
358 <
359 <            # -- create a new directory for each type
360 <            push @targets, $pattern;
361 <            my $dirname=$$hashref{'class'}."_".$type."_".$name;
362 <            my $here="$ENV{LOCALTOP}/$ENV{INTwork}/".$self->{path}."/".$dirname;
363 <            my $makefile=$here."/BuildFile.mk";
364 <
365 <            # -- create link targets to the directory
366 <            push @targets, $dirname;
367 <            print $fh "# -- Link Targets to $type directories\n";
368 <            print $fh "$dirname: make_$dirname\n";
369 <            print $fh "\t\@cd $here; \\\n";
370 <            print $fh "\t\$(MAKE) LatestBuildFile=$makefile _BuildLink_=1".
371 <                        " workdir=$here ".
372 <                        " -f \$(TOOL_HOME)/basics.mk datestamp \$\@; \n\n";
373 <
374 <            # -- write target to make makefile for each directory
375 <            print $fh "# -- Build target directories\n";
376 <            print $fh "make_$dirname:\n";
377 <            print $fh "\tif [ ! -e \"$makefile\" ]; then \\\n";
378 <            print $fh "\t if [ ! -d \"$here\" ]; then \\\n";
379 <            print $fh "\t  mkdir $here; \\\n";
380 <            print $fh "\t fi;\\\n";
381 <            print $fh "\t cd $dirname; \\\n";
382 <            print $fh "\t echo include ".$self->{currentenv}." > ".
383 <                                                        "$makefile; \\\n";
384 <            print $fh "\t echo VPATH+=$ENV{LOCALTOP}/".$self->{path}.
385 <                                        " >> $makefile; \\\n";
386 <            print $fh "\t echo buildname=$name >> $makefile;\\\n";
387 <            print $fh "\t echo ".$dirname.":".$pattern." >> $makefile;\\\n";
388 <            if ( defined (my @file=$mapper->rulesfile($$hashref{'class'})) ) {
389 <             foreach $f ( @file ) {
390 <              print $fh "\t echo -include $f >> $makefile; \\\n";
391 <             }
392 <            }
393 <            print $fh "\tfi\n";
394 <            print $fh "\n";
395 <
396 <            # -- cleaning targets
397 <            push @targets, "clean_$dirname";
398 <            print $fh "# -- cleaning targets\n";
399 <            print $fh "clean::clean_$dirname\n";
400 <            print $fh "clean_".$dirname."::\n";
401 <            print $fh "\t\@echo cleaning $dirname\n";
402 <            print $fh "\t\@if [ -d $here ]; then \\\n";
403 <            print $fh "\tcd $here; \\\n";
404 <            print $fh "\t\$(MAKE) LatestBuildFile=$makefile workdir=".
405 <                        $here." _BuildLink_=1 -f ".
406 <                        "\$(TOOL_HOME)/basics.mk clean; \\\n";
407 <            print $fh "\tfi\n\n";
408 <
409 <
410 <          }
411 <          # -- help targets
412 <          print $fh "helpheader::\n";
413 <          print $fh "\t\@echo Targets available:\n";
414 <          print $fh "\t\@echo ------------------\n\n";
415 <          print $fh "help::helpheader\n";
416 <          foreach $target ( @targets ) {
417 <            print $fh "help::\n";
418 <            print $fh "\t\@echo $target\n"
419 <          }
420 <          print $fh "endif\n";
421 <         } # end else
422 <        }
423 < }
424 <
425 < sub Bin_start {
426 <        my $self=shift;
427 <        my $name=shift;
428 <        my $hashref=shift;
429 <
430 <        my $fileclass;
431 <        my @tools;
432 <        my $tool;
433 <        my $filename;
434 <        my $objectname;
435 <
436 <        $self->verbose(">>          <<");
437 <        
438 <        $self->{switch}->checktag($name,$hashref,'file');
439 <        if ( $self->{Arch} ) {
440 <        if ( ! defined $$hashref{name} ) {
441 <                ($$hashref{name}=$$hashref{file})=~s/\..*//;
442 <        }
443 <        ($filename=$$hashref{file})=~s/\..*//;
444 <
445 <        # Create a new directory for each binary target
446 <        my $dirname="bin_".$$hashref{name};
447 <        AddDir::adddir("$ENV{LOCALTOP}/$ENV{INTwork}/".$self->{path}."/$dirname");
448 <        open (binGNUmakefile,
449 <           ">$ENV{LOCALTOP}/$ENV{INTwork}/".$self->{path}."/$dirname/BuildFile.mk") or die           "Unable to make $ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname/".
450 <           "BuildFile.mk $!\n";
451 <
452 <        # Create the link targets
453 <        $numbins++;
454 <        my $fh=$self->{filehandlestack}[0];
455 <        print $fh <<ENDTEXT;
456 <
457 < # Link Targets to binary directories
458 < ifdef BINMODE
459 < # We dont want to build a library here
460 < override files:=
461 < endif
462 < ifndef BINMODE
463 <
464 < define stepdown_$$hashref{'name'}
465 < if [ -d "$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname" ]; then \\
466 < cd $ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname; \\
467 < \$(MAKE) BINMODE=true LatestBuildFile=$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname/BuildFile.mk workdir=\$(workdir)/$dirname -f \$(TOOL_HOME)/basics.mk datestamp \$\@; \\
468 < fi
469 < endef
470 <
471 < define stepdown2_$$hashref{'name'}
472 < if [ -d "$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname" ]; then \\
473 < cd $ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname; \\
474 < \$(MAKE) BINMODE=true LatestBuildFile=$ENV{LOCALTOP}/$ENV{INTwork}/$self{path}/$dirname/BuildFile.mk workdir=\$(workdir)/$dirname -f \$(TOOL_HOME)/basics.mk datestamp \$\*; \\
475 < fi
476 <
477 < endef
478 <
479 < bin_$$hashref{'name'}_%:: dummy
480 <        \@\$(stepdown2_$$hashref{'name'})
481 <
482 < $$hashref{'name'}_%:: dummy
483 <        \@\$(stepdown_$$hashref{'name'})
484 <
485 < help bin bin_debug bin_debug_local bin_insure bin_Insure clean $$hashref{'name'}:: dummy
486 <        \@\$(stepdown_$$hashref{'name'})
487 <
488 < binfiles+=$$hashref{'file'}
489 < locbinfiles+=$dirname/$$hashref{'file'}
490 < endif
491 <
492 <
493 < ENDTEXT
494 <
495 <
496 < # the binary specifics makefile
497 <        print binGNUmakefile "include ".$self->{currentenv}."\n";
498 <        print binGNUmakefile "VPATH+=$ENV{LOCALTOP}/$self{path}\n";
499 <
500 < # alias for bin_Insure
501 <        print binGNUmakefile <<ENDTEXT;
502 <
503 < bin_insure:bin_Insure
504 < ifdef MAKETARGET_bin_insure
505 < MAKETARGET_$$hashref{name}_Insure=1
506 < endif
507 <
508 < # debuggging target
509 < $$hashref{'name'}_echo_% :: echo_%
510 <
511 < # help targets
512 < help::
513 < \t\@echo Targets For $$hashref{'name'}
514 < \t\@echo -------------------------------------
515 < \t\@echo $$hashref{'name'}  - default build
516 < \t\@echo bin_$$hashref{'name'}_clean - executable specific cleaning
517 < ENDTEXT
518 <
519 < # Make generic rules for each type
520 <        $targettypes={
521 <                "bin" => 'o',
522 <                "bin_debug" => 'd',
523 <                "bin_debug_local" => 'l_d',
524 <                "bin_Insure" => 'Insure'
525 <        };
526 <        #
527 <        foreach $target ( keys %$targettypes ) {
528 <          print binGNUmakefile <<ENDTEXT;
529 <
530 < # Type $target specifics
531 < ifdef MAKETARGET_$target
532 < MAKETARGET_$$hashref{name}_$$targettypes{$target}=1
533 < endif
534 < $target ::$$hashref{name}_$$targettypes{$target}
535 <
536 < bintargets+=$$hashref{name}_$$targettypes{$target}
537 < help::
538 < \t\@echo $$hashref{name}_$$targettypes{$target}
539 < clean::
540 < \t\@if [ -f \$(binarystore)/$$hashref{name}_$$targettypes{$target} ]; then \\
541 < \techo Removing \$(binarystore)/$$hashref{name}; \\
542 < \trm \$(binarystore)/$$hashref{name}_$$targettypes{$target}; \\
543 < \tfi
544 <
545 < ENDTEXT
546 <          ($objectname=$$hashref{file})=~s/\..*/_$$targettypes{$target}\.o/;
547 <          ${"objectname_$$targettypes{$target}"}=$objectname;
548 <          print binGNUmakefile "$objectname:$$hashref{name}.dep\n";
549 <        } # end loop
550 <
551 <        print binGNUmakefile "$$hashref{name}_Insure.exe:.psrc\n";
552 <        print binGNUmakefile "$$hashref{name}_d.exe:$objectname_d\n";
553 <        print binGNUmakefile "\t\$(CClinkCmdDebug)\n";
554 <        print binGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
555 <        print binGNUmakefile "$$hashref{name}_l_d.exe:$objectname_d\n";
556 <        print binGNUmakefile "\t\$(CClinkCmdDebugLocal)\n";
557 <        print binGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
558 <        print binGNUmakefile "$$hashref{name}_Insure.exe:$objectname_Insure\n";
559 <        print binGNUmakefile "\t\$(CClinkCmdInsure)\n";
560 <        print binGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
561 <        print binGNUmakefile "$$hashref{name}_o.exe:$objectname_o\n";
562 <        print binGNUmakefile "\t\$(CClinkCmd)\n";
563 <        print binGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
564 <        print binGNUmakefile "$$hashref{name}.dep:$$hashref{file}\n";
565 <        print binGNUmakefile "-include $$hashref{name}.dep\n";
566 < print binGNUmakefile <<ENDTEXT;
567 < clean::
568 < \t\@if [ -f \$(binarystore)/$$hashref{name} ]; then \\
569 < \techo Removing \$(binarystore)/$$hashref{name}; \\
570 < \trm \$(binarystore)/$$hashref{name}; \\
571 < \tfi
572 <
573 < $$hashref{name}_d.exe:\$(libslocal_d)
574 < $$hashref{name}_o.exe:\$(libslocal)
575 < ifdef MCCABE_DATA_DIR
576 < $$hashref{name}_mccabe.exe: \$(libslocal_d) \$(MCCABE_DATA_DIR)/mccabeinstr/instplus.cpp
577 < endif
578 < $$hashref{name}_Insure.exe:\$(libslocal_I)
579 < $$hashref{name}_d:$$hashref{name}_d.exe
580 <        \@cp $$hashref{name}_d.exe \$(binarystore)/$$hashref{name}
581 < $$hashref{name}_l_d:$$hashref{name}_l_d.exe
582 <        \@cp $$hashref{name}_l_d.exe \$(binarystore)/$$hashref{name}
583 < $$hashref{name}_Insure:$$hashref{name}_Insure.exe
584 <        \@cp $$hashref{name}_Insure.exe \$(binarystore)/$$hashref{name}_Insure
585 < $$hashref{name}:$$hashref{name}_d.exe
586 <        \@mv $$hashref{name}_d.exe \$(binarystore)/$$hashref{name}
587 < $$hashref{name}_o:$$hashref{name}_o.exe
588 <        \@mv $$hashref{name}_o.exe \$(binarystore)/$$hashref{name}
589 < binfiles+=$$hashref{file}
590 < ENDTEXT
591 <        }
592 <        close binGNUmakefile;
593 < }
594 <
595 < sub Module_start {
596 <        my $self=shift;
597 <        my $name=shift;
598 <        my $hashref=shift;
599 <
600 <        my $fileclass;
601 <        my @tools;
602 <        my $tool;
603 <        my $filename;
604 <        my $objectname;
605 <
606 <        $self->verbose(">> In module_start: ".$name." <<");
607 <        
608 <        $self->{switch}->checktag($name,$hashref,'file');
609 <        if ( $self->{Arch} ) {
610 <        if ( ! defined $$hashref{name} ) {
611 <                ($$hashref{name}=$$hashref{file})=~s/\..*//;
612 <        }
613 <        ($filename=$$hashref{file})=~s/\..*//;
614 <
615 <        # Create a new directory for each module target
616 <        my $dirname="module_".$$hashref{name};
617 <        AddDir::adddir("$ENV{LOCALTOP}/$ENV{INTwork}/".$self->{path}."/$dirname");
618 <        open (moduleGNUmakefile,
619 <           ">$ENV{LOCALTOP}/$ENV{INTwork}/".$self->{path}."/$dirname/BuildFile.mk") or die           "Unable to make $ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname/".
620 <           "BuildFile.mk $!\n";
621 <
622 <        # Create the link targets
623 <        $numbins++;
624 <        my $fh=$self->{filehandlestack}[0];
625 <        print $fh <<ENDTEXT;
626 <
627 < # Link Targets to module directories
628 < ifdef MODULEMODE
629 < # We dont want to build a library here
630 < override files:=
631 < endif
632 < ifndef MODULEMODE
117 > sub architecture()
118 >   {
119 >   my ($object,$name,%attributes)=@_;
120 >   my $flag=$self->{archflag};
121 >   push @{$self->{archs}},$flag;
122 >   my $arch=$attributes{name};
123 >   if (($flag) && ($ENV{SCRAM_ARCH}!~/$arch/)){$self->{archflag}=0;}
124 >   }
125  
126 < BINMODE=true
127 <  
128 < define stepdown_$$hashref{'name'}
129 < if [ -d "$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname" ]; then \\
130 < cd $ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname; \\
639 < \$(MAKE) MODULEMODE=true LatestBuildFile=$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname/BuildFile.mk workdir=\$(workdir)/$dirname -f \$(TOOL_HOME)/basics.mk datestamp \$\@; \\
640 < fi
641 < endef
642 <
643 < define stepdown2_$$hashref{'name'}
644 < if [ -d "$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname" ]; then \\
645 < cd $ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/$dirname; \\
646 < \$(MAKE) MODULEMODE=true LatestBuildFile=$ENV{LOCALTOP}/$ENV{INTwork}/$self{path}/$dirname/BuildFile.mk workdir=\$(workdir)/$dirname -f \$(TOOL_HOME)/basics.mk datestamp \$\*; \\
647 < fi
648 <
649 < endef
650 <
651 < module_$$hashref{'name'}_%:: dummy
652 <        \@\$(stepdown2_$$hashref{'name'})
653 <
654 < $$hashref{'name'}_%:: dummy
655 <        \@\$(stepdown_$$hashref{'name'})
656 <
657 < help module module_debug module_debug_local module_insure module_Insure clean $$hashref{'name'}:: dummy
658 <        \@\$(stepdown_$$hashref{'name'})
659 <
660 < modulefiles+=$$hashref{'file'}
661 < locmodulefiles+=$dirname/$$hashref{'file'}
662 < endif
663 <
664 <
665 < ENDTEXT
666 <
667 <
668 < # the module specifics makefile
669 <        print moduleGNUmakefile "include ".$self->{currentenv}."\n";
670 <        print moduleGNUmakefile "VPATH+=$ENV{LOCALTOP}/$self{path}\n";
671 <
672 < # alias for bin_Insure
673 <        print moduleGNUmakefile <<ENDTEXT;
674 <
675 < module_insure:module_Insure
676 < ifdef MAKETARGET_module_insure
677 < MAKETARGET_$$hashref{name}_Insure=1
678 < endif
679 <
680 < # debuggging target
681 < $$hashref{'name'}_echo_% :: echo_%
682 <
683 < # help targets
684 < help::
685 < \t\@echo  
686 < \t\@echo Targets For $$hashref{'name'}
687 < \t\@echo -------------------------------------
688 < \t\@echo $$hashref{'name'}  - default build
689 < \t\@echo module_$$hashref{'name'}_clean - executable specific cleaning
690 < ENDTEXT
691 <
692 < # Make generic rules for each type
693 <        $targettypes={
694 <                "module" => 'o',
695 <                "module_debug" => 'd',
696 <                "module_debug_local" => 'l_d',
697 <                "module_Insure" => 'Insure'
698 <        };
699 <        #
700 <        foreach $target ( keys %$targettypes ) {
701 <          print moduleGNUmakefile <<ENDTEXT;
702 <
703 < # Type $target specifics
704 < ifdef MAKETARGET_$target
705 < MAKETARGET_$$hashref{name}_$$targettypes{$target}=1
706 < endif
707 < $target ::$$hashref{name}_$$targettypes{$target}
708 <
709 < moduletargets+=$$hashref{name}_$$targettypes{$target}
710 < help::
711 < \t\@echo $$hashref{name}_$$targettypes{$target}
712 < clean::
713 < \t\@if [ -f \$(modulestore)/$$hashref{name}_$$targettypes{$target} ]; then \\
714 < \techo Removing \$(modulestore)/$$hashref{name}; \\
715 < \trm \$(modulestore)/$$hashref{name}_$$targettypes{$target}; \\
716 < \tfi
717 <
718 < ENDTEXT
719 <          ($objectname=$$hashref{file})=~s/\..*/_$$targettypes{$target}\.o/;
720 <          ${"objectname_$$targettypes{$target}"}=$objectname;
721 <          print moduleGNUmakefile "$objectname:$$hashref{name}.dep\n";
722 <        } # end loop
723 <        print moduleGNUmakefile "MDFLAGS= -shared -Wl,-soname,\$\@","\n";
724 <        print moduleGNUmakefile "$$hashref{name}_Insure.so:.psrc\n";
725 <        print moduleGNUmakefile "$$hashref{name}_d.so:$objectname_d\n";
726 <        print moduleGNUmakefile "\t\$(CClinkCmdDebug) \$(MDFLAGS)\n";
727 <        print moduleGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
728 <        print moduleGNUmakefile "$$hashref{name}_l_d.so:$objectname_d\n";
729 <        print moduleGNUmakefile "\t\$(CClinkCmdDebugLocal) \$(MDFLAGS)\n";
730 <        print moduleGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
731 <        print moduleGNUmakefile "$$hashref{name}_Insure.so:$objectname_Insure\n";
732 <        print moduleGNUmakefile "\t\$(CClinkCmdInsure) \$(MDFLAGS)\n";
733 <        print moduleGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
734 <        print moduleGNUmakefile "$$hashref{name}_o.so:$objectname_o\n";
735 <        print moduleGNUmakefile "\t\$(CClinkCmd) \$(MDFLAGS)\n";
736 <        print moduleGNUmakefile "\t\@\$(SCRAMPERL) \$(SCRAM_HOME)/src/scramdatestamp \$\@\.ds \$\@ \$\^\n";
737 <        print moduleGNUmakefile "$$hashref{name}.dep:$$hashref{file}\n";
738 <        print moduleGNUmakefile "-include $$hashref{name}.dep\n";
739 < print moduleGNUmakefile <<ENDTEXT;
740 < clean::
741 < \t\@if [ -f \$(modulestore)/lib$$hashref{name} ]; then \\
742 < \techo Removing \$(modulestore)/lib$$hashref{name}; \\
743 < \trm \$(modulestore)/lib$$hashref{name}; \\
744 < \tfi
126 > sub architecture_()
127 >   {
128 >   my ($object,$name,%attributes)=@_;
129 >   $self->{archflag}=pop @{$self->{archs}};
130 >   }
131  
132 <  
133 < $$hashref{name}_d.so:\$(libslocal_d)
134 < $$hashref{name}_o.so:\$(libslocal)
135 < ifdef MCCABE_DATA_DIR
136 < $$hashref{name}_mccabe.so: \$(libslocal_d) \$(MCCABE_DATA_DIR)/mccabeinstr/instplus.cpp
137 < endif
752 < $$hashref{name}_Insure.so:\$(libslocal_I)
753 < $$hashref{name}_d:$$hashref{name}_d.so
754 <        \@cp $$hashref{name}_d.so \$(modulestore)/lib$$hashref{name}
755 < $$hashref{name}_l_d:$$hashref{name}_l_d.so
756 <        \@cp $$hashref{name}_l_d.so \$(modulestore)/lib$$hashref{name}
757 < $$hashref{name}_Insure:$$hashref{name}_Insure.so
758 <        \@cp $$hashref{name}_Insure.so \$(modulestore)/lib$$hashref{name}_Insure
759 < $$hashref{name}:$$hashref{name}_d.so
760 <        \@mv $$hashref{name}_d.so \$(modulestore)/lib$$hashref{name}
761 < $$hashref{name}_o:$$hashref{name}_o.so
762 <        \@mv $$hashref{name}_o.so \$(modulestore)/lib$$hashref{name}.so
763 < modulefiles+=$$hashref{file}
764 < ENDTEXT
765 <        }
766 <        close moduleGNUmakefile;
767 < }
768 <
769 <
770 < sub External_StartTag {
771 <        my $self=shift;
772 <        my $name=shift;
773 <        my $hashref=shift;
774 <
775 <        $self->verbose(">> External_StartTag: NM ".$name." <<");
776 <        
777 <        my $tool;
778 <        if ( $self->{Arch} ) {
779 <        $self->{switch}->checktag($name,$hashref,'ref');
780 <
781 <        # -- oo toolbox stuff
782 <        # - get the appropriate tool object
783 <        $$hashref{'ref'}=~tr[A-Z][a-z];
784 <        if ( ! exists $$hashref{'version'} ) {
785 <         $tool=$self->{toolbox}->gettool($$hashref{'ref'});
786 <        }
787 <        else {
788 <         $tool=$self->{toolbox}->gettool($$hashref{'ref'},$$hashref{'version'});
789 <        }
790 <        if ( ! defined $tool ) {
791 <          $self->{switch}->parseerror("Unknown Tool Specified ("
792 <                                                        .$$hashref{'ref'}.")");
793 <        }
794 <
795 <        # -- old fashioned GNUmakefile stuff
796 <        print GNUmakefile $$hashref{'ref'};
797 <        if ( defined $$hashref{'version'} ) {
798 <                print GNUmakefile "_V_".$$hashref{'version'};
799 <        }
800 <        print GNUmakefile "=true\n";
801 <        
802 <        # -- Sub system also specified?
803 <        if ( exists $$hashref{'use'} ) {
804 <           # -- look for a buildfile
805 <           my @paths=$tool->getfeature("INCLUDE");
806 <           my $file="";
807 <           my ($path,$testfile);
808 <           foreach $path ( @paths ) {
809 <             $testfile=$path."/".$$hashref{'use'}."/BuildFile" ;
810 <             if ( -f $testfile ) {
811 <                $file=$testfile;
812 <                $self->_pushremoteproject($path);
813 <             }
814 <           }
815 <           if ( $file eq "" ) {
816 <             $self->{switch}->parseerror("Unable to find SubSystem $testfile");
817 <           }
818 <           $self->ParseBuildFile_Export($file);
819 <           $self->_popremoteproject();
820 <         }
821 <        }
822 < }      
132 > sub export()
133 >   {
134 >   my ($object,$name,%attributes)=@_;
135 >   if (!$self->{archflag}){return;}
136 >   $self->pushlevel(); # Set nested to 1;
137 >   }
138  
139 < sub Group_start {
140 <        my $self=shift;
141 <        my $name=shift;
142 <        my $hashref=shift;
143 <        
144 <        $self->verbose(">> Group_start: NM ".$name." <<");
145 <        
831 <        $self->{switch}->checktag($name, $hashref, 'name');
832 <        if ( $self->{Arch} ) {
833 <        print GNUmakefile "GROUP_".$$hashref{'name'};
834 <        if ( defined $$hashref{'version'} ) {
835 <                print GNUmakefile "_V_".$$hashref{'version'};
836 <        }
837 <        print GNUmakefile "=true\n";
838 <        }
839 < }      
139 > sub export_()
140 >   {
141 >   my ($object,$name,%attributes)=@_;
142 >   if (!$self->{archflag}){return;}
143 >   $self->{content}->{EXPORT} = $self->{tagcontent};
144 >   $self->poplevel();
145 >   }
146  
147 < sub Use_start
147 > sub lib()
148     {
149 <   my $self=shift;
150 <   my $name=shift;
151 <   my $hashref=shift;
152 <   my $filename;
153 <   use Utilities::SCRAMUtils;
149 >   my ($object,$name,%attributes)=@_;
150 >   # The getter part:
151 >   if (ref($object) eq __PACKAGE__)
152 >      {
153 >      # Return an array of required libs:
154 >      return $self->{content}->{LIB};      
155 >      }
156 >   if (!$self->{archflag}){return;}
157 >   my $libname = $attributes{'name'};
158 >   # We have a libname, add it to the list:
159 >   $self->{nested} == 1 ? push(@{$self->{tagcontent}->{LIB}}, $libname)
160 >      : push(@{$self->{content}->{LIB}}, $libname);
161 >   }
162  
163 <   $self->verbose(">> Use_start: NM ".$name." <<");
164 <  
165 <   $self->{switch}->checktag($name, $hashref, "name");
166 <   if ( $self->{Arch} )
163 > sub makefile()
164 >   {
165 >   my ($object,$name,%attributes)=@_;
166 >   # The getter part:
167 >   if (ref($object) eq __PACKAGE__)
168        {
169 <      if ( exists $$hashref{'group'} )
170 <         {
171 <         print GNUmakefile "GROUP_".$$hashref{'group'}."=true\n";
172 <         }
173 <      if ( ! defined $self->{remoteproject} )
169 >      return $self->{content}->{MAKEFILE};
170 >      }
171 >   }
172 >
173 > sub makefile_()
174 >   {
175 >   my ($object,$name,$cdata)=@_;
176 >   if (!$self->{archflag}){return;}
177 >   $self->{nested} == 1 ? push(@{$self->{tagcontent}->{MAKEFILE}}, join("\n",@$cdata))
178 >      : push(@{$self->{content}->{MAKEFILE}}, join("\n",@$cdata));
179 >   }
180 >
181 > sub flags()
182 >   {
183 >   my ($object,$name,%attributes)=@_;
184 >   # The getter part:
185 >   if (ref($object) eq __PACKAGE__)
186 >      {
187 >      # Return an array of ProductStore hashes:
188 >      return $self->{content}->{FLAGS};
189 >      }
190 >   if (!$self->{archflag}){return;}
191 >   # Extract the flag name and its value:
192 >   my ($flagname,$flagvaluestring) = each %attributes;
193 >   $flagname =~ tr/[a-z]/[A-Z]/; # Keep flag name uppercase
194 >   chomp($flagvaluestring);
195 >   my @flagvalues = ( $flagvaluestring );
196 >   # Is current tag within another tag block?
197 >   if ($self->{nested} == 1)
198 >      {
199 >      # Check to see if the current flag name is already stored in the hash. If so,
200 >      # just add the new values to the array of flag values:
201 >      if (exists ($self->{tagcontent}->{FLAGS}->{$flagname}))
202           {
203 <         $filename=SCRAMUtils::checkfile("/$ENV{INTsrc}/$$hashref{name}/BuildFile");
203 >         push(@{$self->{tagcontent}->{FLAGS}->{$flagname}},@flagvalues);
204           }
205        else
206           {
207 <         $filename=$self->{remoteproject}."/$$hashref{name}/BuildFile";
865 <         # Not sure how useful this statement is, so I'll remove it for now:
866 <         # print STDERR "Trying $filename\n";
867 <         if ( ! -f $filename ) { $filename=""; };
207 >         $self->{tagcontent}->{FLAGS}->{$flagname} = [ @flagvalues ];
208           }
209 <      if ( $filename ne "" )
209 >      }
210 >   else
211 >      {
212 >      if (exists ($self->{content}->{FLAGS}->{$flagname}))
213           {
214 <         $self->ParseBuildFile_Export( $filename );
214 >         push(@{$self->{content}->{FLAGS}->{$flagname}},@flagvalues);
215           }
216        else
217           {
218 <         $self->{switch}->parseerror("Unable to detect Appropriate ".
876 <                                     "decription file for <$name name=".$$hashref{name}.">");
218 >         $self->{content}->{FLAGS}->{$flagname} = [ @flagvalues ];
219           }
220        }
221     }
222  
223 < sub CheckBuildFile {
882 <         my $self=shift;
883 <         my $classdir=shift;
884 <         my $ClassName="";
885 <         my $thisfile="$classdir/$buildfile";
886 <        
887 <         if ( -e $ENV{LOCALTOP}."/".$thisfile ) {
888 <            $DefaultBuildfile="$ENV{LOCALTOP}/$thisfile";
889 <            $self->ParseBuildFile($ENV{LOCALTOP}, $classdir, $buildfile);
890 <         }
891 <         elsif ( -e $ENV{RELEASETOP}."/".$thisfile ) {
892 <            $DefaultBuildfile="$ENV{RELEASETOP}/$thisfile";
893 <            $self->ParseBuildFile($ENV{RELEASETOP}, $classdir, $buildfile);
894 <         }
895 <         $self->verbose(">> CheckBuildFile: FN ".$thisfile." CN ".$ClassName." <<");
896 <         return $ClassName;
897 < }
898 <
899 < # List association groups between <AssociateGroup> tags
900 < # seperated by newlines or spaces
901 < sub AssociateGroup {
902 <        my $self=shift;
903 <        my $name=shift;
904 <        my $string=shift;
905 <        my $word;
906 <
907 <        $self->verbose(">> AssociateGroup: NM ".$name." ST ".$string." <<");
908 <        
909 <        if ( $self->{Arch} ) {
910 <        foreach $word ( (split /\s/, $string) ){
911 <                chomp $word;
912 <                next if /^#/;
913 <                if ( $word=~/none/ ) {
914 <                        $self->{ignore}=1;
915 <                }
916 <        }
917 <        }
918 < }
919 <
920 < sub Arch_Start
223 > sub allflags()
224     {
225     my $self=shift;
226 <   my $name=shift;
227 <   my $hashref=shift;
228 <  
229 <   $self->verbose(">> Arch_Start: NM ".$name." <<");
230 <  
231 <   $self->{switch}->checktag($name, $hashref,'name');
232 <  
233 < #   if ($ENV{SCRAM_ARCH} =~ /$$hashref{name}$/)
234 <   if ( $$hashref{name} eq $ENV{SCRAM_ARCH} )
226 >   # Return hash data for flags:
227 >   return $self->{content}->{FLAGS};
228 >   }
229 >
230 > sub bin()
231 >   {
232 >   my ($object,$name,%attributes) = @_;
233 >   if (!$self->{archflag}){return;}
234 >   $self->pushlevel(\%attributes);# Set nested to 1;
235 >   }
236 >
237 > sub bin_()
238 >   {
239 >   my ($object,$name,%attributes) = @_;
240 >   if (!$self->{archflag}){return;}
241 >   # Need unique name for the binary (always use name of product). Either use "name"
242 >   # given, or use "file" value minus the ending:
243 >   if (exists ($self->{id}->{'name'}))
244        {
245 < #      print "HASHREFNAME= ",$$hashref{name},"\n";     # The tag read from BuildFile
934 < #      print "Scram arch()? ",$ENV{SCRAM_ARCH},"\n";   # Also SCRAM_ARCH
935 <      $self->{Arch}=1;
245 >      $name = $self->{id}->{'name'};
246        }
247     else
248        {
249 <      $self->{Arch}=0;
249 >      ($name) = ($self->{id}->{'file'} =~ /(.*)?\..*$/);
250        }
251 < #   ( ($ENV{SCRAM_ARCH}=~/$$hashref{name}.*/) )? ($self->{Arch}=1)
252 < #      : ($self->{Arch}=0);
253 <  
254 <   $self->verbose(($self->{Arch}?"OK":"skipping")." ".$$hashref{name});
945 <   push @{$self->{ARCHBLOCK}}, $self->{Arch};
251 >
252 >   # Store the data:
253 >   $self->productcollector($name,'bin','BIN');
254 >   $self->poplevel();
255     }
256  
257 < sub Arch_End {
258 <        my $self=shift;
259 <        my $name=shift;
260 <        
261 <        $self->verbose(">> Arch_End: NM ".$name." <<");
262 <
954 <        pop @{$self->{ARCHBLOCK}};
955 <        $self->{Arch}=$self->{ARCHBLOCK}[$#{$self->{ARCHBLOCK}}];
956 < }
957 <
958 < # Split up the Class Block String into a useable array
959 < sub _CutBlock {
960 <    my $self=shift;
961 <    my $string= shift @_;
962 <
963 <    $self->verbose(">> _CutBlock: ST ".$string." <<");
964 <    
965 <    @BlockClassA = split /\//, $string;
966 < }
967 <
968 < sub OutToMakefile {
969 <        my $self=shift;
970 <        my $name=shift;
971 <        my @vars=@_;
972 <        
973 <        $self->verbose(">> OutToMakefile: <<");
974 <
975 <        if ( $self->{Arch} ) {
976 <          $self->verbose(">> CONT: ".$#vars." lines <<");
977 <          print GNUmakefile @vars;
978 <        }
979 < }
980 <
981 < sub OutToScreen {
982 <        my $name=shift;
983 <        my @vars=@_;
984 <        
985 <        if ( $self->{Arch} ) {
986 <          print @vars;
987 <        }
988 < }
989 < sub setBlockClassPath {
990 <        my $self=shift;
991 <        my $name=shift;
992 <        my $hashref=shift;
993 <
994 <        $self->verbose(">> setBlockClassPath: NM ".$name." <<");
995 <        
996 <        $self->{switch}->checktag($name, $hashref, 'path');
997 <        $self->{BlockClassPath}=$self->{BlockClassPath}.":".$$hashref{path};
998 <        $self->_CutBlock($$hashref{path});
999 < }
1000 <
1001 < sub BlockClassPath {
1002 <        my $self=shift;
1003 <
1004 <        $self->verbose(">> BlockClassPath: <<");
1005 <
1006 <        return $self->{BlockClassPath};
1007 < }
1008 <
1009 < sub export_start_export {
1010 <        my $self=shift;
1011 <        my $name=shift;
1012 <        my $hashref=shift;
1013 <
1014 <        $self->verbose(">> export_start_export: NM ".$name." <<");
1015 <        
1016 <        $self->{switch}->opengroup("__export");
1017 < }
1018 <
1019 < sub export_start {
1020 <        my $self=shift;
1021 <        my $name=shift;
1022 <        my $hashref=shift;
1023 <
1024 <        $self->verbose(">> export_start: NM ".$name." <<");
1025 <        
1026 <        $self->{switch}->opengroup("__export");
1027 <        if ( exists $$hashref{autoexport} ) {
1028 <          print GNUmakefile "scram_autoexport=".$$hashref{autoexport}."\n";
1029 <          if ( $$hashref{autoexport}=~/true/ ) {
1030 <           $self->{switch}->allowgroup("__export","makebuild");
1031 <          }
1032 <          else {
1033 <           $self->{switch}->disallowgroup("__export","makebuild");
1034 <          }
1035 <        }
1036 <        # -- allow default setting from other makefiles
1037 <        print GNUmakefile "ifeq (\$(scram_autoexport),true)\n";
1038 < }
1039 <
1040 < sub export_end_export {
1041 <        my $self=shift;
1042 <        $self->verbose(">> export_end_export: <<");
1043 <        $self->{switch}->closegroup("__export");
1044 < }
1045 <
1046 < sub export_end {
1047 <        my $self=shift;
1048 <        $self->verbose(">> export_end: <<");
1049 <        $self->{switch}->closegroup("__export");
1050 <        print GNUmakefile "endif\n";
1051 < }
257 > sub library()
258 >   {
259 >   my ($object,$name,%attributes) = @_;
260 >   if (!$self->{archflag}){return;}
261 >   $self->pushlevel(\%attributes);# Set nested to 1;
262 >   }
263  
264 < #
265 < # Standard lib tag
266 < #
267 < sub lib_start
264 > sub library_()
265 >   {
266 >   my ($object,$name,%attributes) = @_;
267 >   if (!$self->{archflag}){return;}
268 >   # Need unique name for the library (always use name of product). Either use "name"
269 >   # given, or use "file" value minus the ending:
270 >   if (exists ($self->{id}->{'name'}))
271 >      {
272 >      $name = $self->{id}->{'name'};
273 >      }
274 >   else
275 >      {
276 >      ($name) = ($self->{id}->{'file'} =~ /(.*)?\..*$/);
277 >      }
278 >
279 >   # Store the data:
280 >   $self->productcollector($name,'lib','LIBRARY');
281 >   $self->poplevel();
282 >   }
283 >
284 > sub productcollector()
285     {
286     my $self=shift;
287 <   my $name=shift;
288 <   my $hashref=shift;
289 <  
290 <   $self->verbose(">> lib_start: NM ".$name." <<");
287 >   my ($name,$typeshort,$typefull)=@_;
288 >   # Create a new Product object for storage of data:
289 >   use BuildSystem::Product;
290 >   my $product = BuildSystem::Product->new();
291 >   # Store the name:
292 >   $product->name($name);
293 >   $product->type($typeshort);
294 >   # Store the files. Take the BuildFile path as the initial path for
295 >   # expanding source file globs:
296 >   $product->_files($self->{id}->{'file'},[ $self->{scramdoc}->filetoparse() ]);
297 >   # Store the data content:
298 >   $product->_data($self->{tagcontent});
299 >   # And store in a hash (all build products in same place):
300 >   $self->{content}->{BUILDPRODUCTS}->{$typefull}->{$name} = $product;
301 >   }
302 >
303 > sub pushlevel
304 >   {
305 >   my $self = shift;
306 >   my ($info)=@_;
307    
308 <   $self->{switch}->checktag($name, $hashref, 'name');
308 >   $self->{id} = $info if (defined $info);
309 >   $self->{nested} = 1;
310 >   $self->{tagcontent}={};
311 >   }
312 >
313 > sub poplevel
314 >   {
315 >   my $self = shift;
316 >   delete $self->{id};
317 >   delete $self->{nested};
318 >   delete $self->{tagcontent};
319 >   }
320 >
321 > sub dependencies()
322 >   {
323 >   my $self=shift;
324 >   # Make a copy of the variable so that
325 >   # we don't have a DEPENDENCIES entry in RAWDATA:
326 >   my %DEPS=%{$self->{DEPENDENCIES}};
327 >   delete $self->{DEPENDENCIES};
328 >   return \%DEPS;
329 >   }
330 >
331 > sub skippeddirs()
332 >   {
333 >   my $self=shift;
334 >   my ($here)=@_;
335 >   my $skipped;
336  
337 <   if ( $self->{Arch} )
337 >   if ($self->{content}->{SKIPPEDDIRS}->[0] == 1)
338        {
339 <      print GNUmakefile "lib+=$$hashref{name}\n";
339 >      $skipped = [ @{$self->{content}->{SKIPPEDDIRS}} ];
340 >      delete $self->{content}->{SKIPPEDDIRS};
341        }
342 +  
343 +   delete $self->{content}->{SKIPPEDDIRS};
344 +   return $skipped;
345     }
346  
347 < # Standard debug lib tag
348 < #
349 < sub debuglib_start
347 > sub hasexport()
348 >   {
349 >   my $self=shift;
350 >   # Check to see if there is a valid export block:
351 >   my $nkeys = $self->exporteddatatypes();
352 >   $nkeys > 0 ? return 1 : return 0;
353 >   }
354 >
355 > sub has()
356 >   {
357 >   my $self=shift;
358 >   my ($datatype)=@_;  
359 >   (exists ($self->{content}->{$datatype})) ? return 1 : return 0;
360 >   }
361 >
362 > sub exported()
363 >   {
364 >   my $self=shift;
365 >   # Return a hash. Keys are type of data provided:
366 >   return ($self->{content}->{EXPORT});
367 >   }
368 >
369 > sub exporteddatatypes()
370 >   {
371 >   my $self=shift;
372 >   # Return exported data types:
373 >   return keys %{$self->{content}->{EXPORT}};
374 >   }
375 >
376 > sub buildproducts()
377     {
378     my $self=shift;
379 <   my $name=shift;
380 <   my $hashref=shift;
379 >   # Returns hash of build products and their data:
380 >   return $self->{content}->{BUILDPRODUCTS};
381 >   }
382 >
383 > sub values()
384 >   {
385 >   my $self=shift;
386 >   my ($type)=@_;
387 >   # Get a list of values from known types
388 >   return $self->{content}->{BUILDPRODUCTS}->{$type};
389 >   }
390 >
391 > sub basic_tags()
392 >   {
393 >   my $self=shift;
394 >   my $datatags=[];
395 >   my $buildtags=[ qw(BIN LIBRARY BUILDPRODUCTS) ];
396 >   my $skiptags=[ qw(ARCH EXPORT USE CLASSPATH) ];
397 >   my $otherskiptags=[ qw( SKIPPEDDIRS ) ];
398 >   my @all_skip_tags;
399    
400 <   $self->verbose(">> debuglib_start: NM ".$name." <<");
1081 <   $self->{switch}->checktag($name, $hashref, 'name');
400 >   push(@all_skip_tags,@$skiptags,@$buildtags,@$otherskiptags);
401  
402 <   if ( $self->{Arch} )
402 >   foreach my $t (keys %{$self->{content}})
403        {
404 <      print GNUmakefile "debuglib+=$$hashref{name}\n";
404 >      push(@$datatags,$t),if (! grep($t eq $_, @all_skip_tags));
405        }
406 +   return @{$datatags};
407     }
408  
409 < #
1090 < # libtype specification
1091 < #
1092 < sub LibType_Start {
1093 <        my $self=shift;
1094 <        my $name=shift;
1095 <        my $hashref=shift;
1096 <        
1097 <        $self->verbose(">> LibType_Start: NM ".$name." <<");
1098 <        
1099 <        if ( $self->{Arch} ) {
1100 <        if ( defined $self->{libtype_conext} ) {
1101 <          $self->{switch}->parseerror("<$name> tag cannot be specified".
1102 <                " without a </$name> tag to close previous context");
1103 <        }
1104 <        else {
1105 <        $self->{libtype_conext}=1;
1106 <        $self->{switch}->checktag($name, $hashref, 'type');
1107 <        
1108 <        print GNUmakefile "# Specify Library Type\n";
1109 <        print GNUmakefile "DefaultLibsOff=yes\n";
1110 <        if ( $$hashref{'type'}=~/^archive/i ) {
1111 <          print GNUmakefile "LibArchive=true\n";
1112 <        }
1113 <        elsif ($$hashref{'type'}=~/debug_archive/i ) {
1114 <          print GNUmakefile "LibDebugArchive=true\n";
1115 <        }
1116 <        elsif ($$hashref{'type'}=~/debug_shared/i ) {
1117 <          print GNUmakefile "LibDebugShared=true\n";
1118 <        }
1119 <        elsif ($$hashref{'type'}=~/shared/i ) {
1120 <          print GNUmakefile 'LibShared=true'."\n";
1121 <        }
1122 <        print GNUmakefile "\n";
1123 <        }
1124 <        }
1125 < }
1126 <
1127 < sub LibType_text {
1128 <        my $self=shift;
1129 <        my $name=shift;
1130 <        my $string=shift;
1131 <        $self->verbose(">> LibType_text: NM ".$name." <<");
1132 <
1133 <        if ( $self->{Arch} ) {
1134 <          $string=~s/\n/ /g;
1135 <          print GNUmakefile "libmsg::\n\t\@echo Library info: ";
1136 <          print GNUmakefile $string;
1137 <          print GNUmakefile "\n";
1138 <        }
1139 < }
1140 <
1141 < sub LibType_end {
1142 <        my $self=shift;
1143 <        my $name=shift;
1144 <
1145 <        $self->verbose(">> LibType_end: NM ".$name." <<");
1146 <
1147 <        undef $self->{libtype_conext};
1148 < }
1149 <
1150 < sub Environment_start {
1151 <        my $self=shift;
1152 <        my $name=shift;
1153 <        my $hashref=shift;
1154 <
1155 <        $self->verbose(">> Environment_start: NM ".$name." <<");
1156 <        
1157 <        if ( $self->{Arch} ) {
1158 <          $self->{envnum}++;
1159 <
1160 <          # open a new Environment File
1161 <          my $envfile="$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/Env_".
1162 <                $self->{envnum}.".mk";
1163 <          use FileHandle;
1164 <          my $fh=FileHandle->new();
1165 <          open ($fh,">$envfile") or die "Unable to open file $envfile \n$!\n";
1166 <          push @{$self->{filehandlestack}}, $fh;
1167 <          *GNUmakefile=$fh;
1168 <
1169 <          # include the approprate environment file
1170 <          if ( $self->{envlevel} == 0 ) {
1171 <             print GNUmakefile "include $ENV{LOCALTOP}/$ENV{INTwork}/".
1172 <                $self->{path}."/BuildFile.mk\n";
1173 <          }
1174 <          else {
1175 <             print GNUmakefile "include $ENV{LOCALTOP}/$ENV{INTwork}/".
1176 <                $self->{path}."/Env_".$self->{Envlevels}[$self->{envlevel}].".mk\n";
1177 <          }
1178 <          $self->{envlevel}++;
1179 <          $self->{Envlevels}[$self->{envlevel}]=$self->{envnum};
1180 <          $self->{currentenv}="$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/Env_$self->{envnum}.mk";
1181 <        }
1182 < }
1183 <
1184 < sub Environment_end {
1185 <        my $self=shift;
1186 <        my $fd;
1187 <
1188 <        $self->verbose(">> Environment_end: NM ".$name." <<");
1189 <
1190 <        if ( $self->{Arch} ) {
1191 <          $self->{envlevel}--;
1192 <          if ( $self->{envlevel} < 0 ) {
1193 <            print "Too many </Environent> Tags on $self->{switch}->line()\n";
1194 <            exit 1;
1195 <          }
1196 <          close GNUmakefile;
1197 <          # restore the last filehandle
1198 <          $fd=pop @{$self->{filehandlestack}};
1199 <          close $fd;
1200 <          *GNUmakefile=$self->{filehandlestack}[$#{$self->{filehandlestack}}];
1201 <          if ( $self->{envlevel} < 1 ) {
1202 <            $self->{currentenv}="$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/".
1203 <                        "BuildFile.mk";
1204 <          }
1205 <          else {
1206 <            $self->{currentenv}=
1207 <             "$ENV{LOCALTOP}/$ENV{INTwork}/$self->{path}/Env_".
1208 <                $self->{Envlevels}[$self->{envlevel}];
1209 <          }
1210 <        }
1211 < }
1212 <
1213 < sub Store_start {
1214 <        my $self=shift;
1215 <        my $name=shift;
1216 <        my $hashref=shift;
1217 <
1218 <        $self->verbose(">> Store_start: NM ".$name." <<");
1219 <
1220 <        if ( $self->{Arch} ) {
1221 <          $self->{switch}->checktag( $name, $hashref, 'name' );
1222 <
1223 <          # -- store creation
1224 <          my $dir=$$hashref{'name'};
1225 <          AddDir::adddir($ENV{LOCALTOP}."/".$dir);
1226 <          if ( exists $$hashref{'type'} ) {
1227 <            # -- architecture specific store
1228 <            if ( $$hashref{'type'}=~/^arch/i ) {
1229 <                $dir=$dir."/".$ENV{SCRAM_ARCH};
1230 <                AddDir::adddir($ENV{LOCALTOP}."/".$dir);
1231 <            }
1232 <            else {
1233 <                $self->parseerror("Unknown type in <$name> tag");
1234 <            }
1235 <          }
1236 <
1237 <          # -- set make variables for the store
1238 <          print GNUmakefile "SCRAMSTORENAME_".$$hashref{'name'}.":=".$dir."\n";
1239 <          print GNUmakefile "SCRAMSTORE_".$$hashref{'name'}.":=".
1240 <                                        $ENV{LOCALTOP}."/".$dir."\n";
1241 <          print GNUmakefile "VPATH+=".$ENV{LOCALTOP}
1242 <                        ."/".$dir.":".$ENV{RELEASETOP}."/".$dir."\n";
1243 <        }
1244 < }
1245 <
1246 < sub CompilerMap_Start
409 > sub clean()
410     {
1248   ###############################################################
1249   # CompilerMap_Start                                           #
1250   ###############################################################
1251   # modified : Fri Oct  4 15:08:39 2002 / SFA                   #
1252   # params   :                                                  #
1253   #          :                                                  #
1254   #          :                                                  #
1255   #          :                                                  #
1256   # function : Create a map between a SUBARCH and specific      #
1257   #          : compiler and version.                            #
1258   #          :                                                  #
1259   #          :                                                  #
1260   ###############################################################
411     my $self=shift;
412 <   my $name=shift;
1263 <   my $hashref=shift;
412 >   my (@tags) = @_;
413  
414 <   $self->verbose(">> CompilerMap_Start: NM ".$name." <<");
415 <   # We can only map compilers to already-defined architectures, so
416 <   # we check for 'Arch':
417 <   if ( $self->{Arch} )
418 <      {
1270 <      my @tagnames=keys %{$hashref};
1271 <      my @tagvalues=values %{$hashref};
1272 <      
1273 <      foreach my $tag ( @tagnames )
1274 <         {
1275 <         $self->{switch}->checktag($name,$hashref,$tag);
1276 <         print GNUmakefile $tag."=".$$hashref{$tag}."\n";
414 >   # Delete some useless entries:
415 >   delete $self->{simpledoc};
416 >   delete $self->{id};
417 >   delete $self->{tagcontent};
418 >   delete $self->{nested};
419  
420 <         if ( defined $$hashref{'version'} )
421 <            {
422 <            print GNUmakefile "_V_".$$hashref{'version'};
1281 <            }
1282 <         print GNUmakefile "=true\n";
1283 <         }
1284 < #        $self->{switch}->checktag($name,$hashref,'ref');
1285 <
1286 < #       # -- oo toolbox stuff
1287 < #       # - get the appropriate tool object
1288 < #       $$hashref{'ref'}=~tr[A-Z][a-z];
1289 < #       if ( ! exists $$hashref{'version'} ) {
1290 < #        $tool=$self->{toolbox}->gettool($$hashref{'ref'});
1291 < #       }
1292 < #       else {
1293 < #        $tool=$self->{toolbox}->gettool($$hashref{'ref'},$$hashref{'version'});
1294 < #       }
1295 < #       if ( ! defined $tool ) {
1296 < #         $self->{switch}->parseerror("Unknown Tool Specified ("
1297 < #                                                       .$$hashref{'ref'}.")");
1298 < #       }
1299 <
1300 < #       # -- old fashioned GNUmakefile stuff
1301 < #       print GNUmakefile $$hashref{'ref'};
1302 < #       if ( defined $$hashref{'version'} ) {
1303 < #               print GNUmakefile "_V_".$$hashref{'version'};
1304 < #       }
1305 < #       print GNUmakefile "=true\n";
1306 <        
1307 < #       # -- Sub system also specified?
1308 < #       if ( exists $$hashref{'use'} ) {
1309 < #          # -- look for a buildfile
1310 < #          my @paths=$tool->getfeature("INCLUDE");
1311 < #          my $file="";
1312 < #          my ($path,$testfile);
1313 < #          foreach $path ( @paths ) {
1314 < #            $testfile=$path."/".$$hashref{'use'}."/BuildFile" ;
1315 < #            if ( -f $testfile ) {
1316 < #               $file=$testfile;
1317 < #               $self->_pushremoteproject($path);
1318 < #            }
1319 < #          }
1320 < #          if ( $file eq "" ) {
1321 < #            $self->{switch}->parseerror("Unable to find SubSystem $testfile");
1322 < #          }
1323 < #          $self->ParseBuildFile_Export($file);
1324 < #          $self->_popremoteproject();
1325 < #        }
1326 <      }
1327 <   else
420 >   delete $self->{DEPENDENCIES};
421 >  
422 >   map
423        {
424 <      return;
425 <      }
426 <   }
424 >      delete $self->{content}->{$_} if (exists($self->{content}->{$_}));
425 >      } @tags;
426 >  
427 >   return $self;
428 >   }
429  
430 + sub AUTOLOAD()
431 +   {
432 +   my ($xmlparser,$name,%attributes)=@_;
433 +   return if $AUTOLOAD =~ /::DESTROY$/;
434 +   my $name=$AUTOLOAD;
435 +   $name =~ s/.*://;
436 +   }
437  
438 + 1;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines