diff -r 22486c9c7b15 -r 378360dbbdba sbsv1/abld/bldmake/wrappermakefile.pm --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sbsv1/abld/bldmake/wrappermakefile.pm Wed Jun 30 11:35:58 2010 +0800 @@ -0,0 +1,158 @@ +# Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies). +# All rights reserved. +# This component and the accompanying materials are made available +# under the terms of "Eclipse Public License v1.0" +# which accompanies this distribution, and is available +# at the URL "http://www.eclipse.org/legal/epl-v10.html". +# +# Initial Contributors: +# Nokia Corporation - initial contribution. +# +# Contributors: +# +# Description: +# + + +package wrappermakefile; +require Exporter; +@wrappermakefile::ISA=qw(Exporter); +@wrappermakefile::EXPORT=qw( + GenerateWrapper +); + +use Output; + +my (@ExtensionUsedBefore); +my $ExtTemplatesPath="$ENV{EPOCROOT}epoc32/tools/makefile_templates/"; +$ExtTemplatesPath=~ s/\\/\//g; # convert win32 slashes to unix slashes +my $DieRef; +our $ExtMakefileMissing = 0; + +# Add prototyes to avoid -w warnings +sub GenerateWrapper($$$$@); +sub ReadMetaFile($$$$); + + +sub GenerateWrapper($$$$@) { + my ($Plat,$OutDir, $ErrorString, $dieRef, @ExtensionBlockData) = @_; + $DieRef = $dieRef; + +# Generates a makefile which contains the settings for each invocation of an extension and calls +# through to the extension template makefile in /epoc32/tools/makefile_templates. +# @ExtensionBlockData holds the settings (makefile MACROs) defined within the start..end block in the bld.inf. + + my $ExtHeader = shift(@ExtensionBlockData); + + if (uc $ExtHeader->[0] ne "EXTENSION") { + &main::FatalError("$ErrorString : Extension Template blocks must contain the 'extension' keyword.\n"); + } + if ($ExtHeader->[1] eq "") { + &main::FatalError("$ErrorString : The 'extension' does not have a name, the correct format is: 'start extension '.\n"); + } + my $ExtName = $ExtHeader->[1]; + +# Ensure that each extension invocation is uniquely identified by means of the global array +# ExtensionUsedBefore. + my $Count=0; + push @ExtensionUsedBefore, $ExtName.$Plat; + foreach my $item(@ExtensionUsedBefore) { + if ($item eq $ExtName.$Plat) { + $Count = $Count + 1; + } + } + +# Process the meta information for this extension template. + my %Data; + my %WrapperMakefileData = ReadMetaFile($ExtName, $ErrorString, \$Data{Makefile},$dieRef); + if ($ExtMakefileMissing) + { + main::ExtensionMakefileMissing($ExtMakefileMissing); + return; + } + $Data{Ext}='.MK'; + $Data{Base}=$ExtName."_".$Plat."_".$Count; + $Data{Path}=$OutDir."wrappermakefiles/"; + +# Process ExtensionBlockData + foreach my $ExtBlockStatement (@ExtensionBlockData) { + my $Key = shift(@$ExtBlockStatement); + $WrapperMakefileData{$Key}=$ExtBlockStatement; + } + +# CreateWrapperMakefile + &Output("# Bldmake generated wrapper makefile\n\n"); + foreach my $Key (keys (%WrapperMakefileData)) + { + &Output("$Key = "); + foreach my $item(@{$WrapperMakefileData{$Key}}) { + &Output(" $item"); + } + &Output("\n"); + } + my $Filename = lc("$ExtName$Data{Ext}"); + &Output("\ninclude $ExtTemplatesPath$Filename"); + my $Path = lc("$Data{Path}"); + &main::WriteOutFileL(lc ($Path.$ExtName."_".$Plat."_".$Count.$Data{Ext})); + %WrapperMakefileData = (); + return %Data; +} + +# Read extension meta file data +sub ReadMetaFile($$$$) { + my ($ExtName, $ErrorString, $Makefile,$dieRef) = @_; + +# Parse the .meta file (found via $ExtName) for this extension template and return a hash +# containing the default values (makefile MACROs) for this template. +# $Makefile is updated to indicate whether this a gnumake or nmake makefile. + + my %MetaData; + my $Filename = lc("$ExtName"); + $ExtMakefileMissing=0; + if (!open(METAFILE,"$ExtTemplatesPath$Filename.meta")) + { + &main::WarnOrDie($dieRef, "$ErrorString : Extension: $ExtName - cannot open META file: $ExtTemplatesPath$Filename.meta\n"); + $ExtMakefileMissing = 1; + return; + } + LINE: while () { + chomp; + my @Elements = split(/\s*\s\s*/); + my $Keyword = uc shift(@Elements); + + if ((! $Keyword) or ($Keyword =~ m/^#/)) { + next LINE; + } + + if ($Keyword eq "MAKEFILE") { + my $Makefiletype = uc shift(@Elements); + if ($Makefiletype eq "GNUMAKE") { + $$Makefile=1; + } + if ($Makefiletype eq "NMAKE") { + $$Makefile=2; + } + } + elsif ($Keyword eq "OPTION") { + my $Key = shift(@Elements); + if ((! $Key) or (! $Elements[0])) { + &main::FatalError("$ErrorString : There is a syntax error in the META file ($ExtTemplatesPath$Filename.meta) for this extension ($ExtName) - the correct format for default options is: 'option '"); + } + my @Values = @Elements; + $MetaData{$Key}=\@Values; + } + elsif (($Keyword eq "TECHSTREAM") or ($Keyword eq "PLATFORM")) { + # not used + } + else { + &main::FatalError("$ErrorString : There is a syntax error in the META file ($ExtTemplatesPath$Filename.meta) for this extension ($ExtName) - unrecognised keyword:$Keyword"); + } + } + if (! $$Makefile) { + &main::FatalError("$ErrorString : There is a syntax error in the META file ($ExtTemplatesPath$Filename.meta) for this extension ($ExtName) - makefile type not specified [gnumake|nmake]"); + } + close(METAFILE) or &main::FatalError("$ErrorString : Extension: $ExtName - cannot close Meta File:$ExtTemplatesPath$ExtName.meta\n"); + return %MetaData; +} + +1;