summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiikka Heikkinen <miikka.heikkinen@digia.com>2011-11-03 12:05:31 (GMT)
committerMiikka Heikkinen <miikka.heikkinen@digia.com>2011-11-03 12:32:46 (GMT)
commitf5b50368ae8ea7e9b1bf3ff6641d665389c6271b (patch)
tree898440e712bd30513f6976f0e4e96d5516dfe8de
parentdebf1ea609ee10eb9429f02d1d1f63a2490529d5 (diff)
downloadQt-f5b50368ae8ea7e9b1bf3ff6641d665389c6271b.zip
Qt-f5b50368ae8ea7e9b1bf3ff6641d665389c6271b.tar.gz
Qt-f5b50368ae8ea7e9b1bf3ff6641d665389c6271b.tar.bz2
Improve whatlog generation for Symbian tools2 builds.
- Headerexport script is only called once, whatlog is stored into a file - Sed is only called once - Properly added generated tools to whatlog Task-number: QTBUG-22521 Reviewed-by: Sami Merila
-rw-r--r--config.profiles/symbian/headerexport140
-rw-r--r--config.profiles/symbian/qtconfig.flm19
2 files changed, 68 insertions, 91 deletions
diff --git a/config.profiles/symbian/headerexport b/config.profiles/symbian/headerexport
index d252b26..c62f3db 100644
--- a/config.profiles/symbian/headerexport
+++ b/config.profiles/symbian/headerexport
@@ -60,7 +60,7 @@ my %moduleheaders = ( # restrict the module headers to those found in relative p
#$modules{"QtCore"} .= ";$basedir/mkspecs/" . $ENV{"MKSPEC"} if defined $ENV{"MKSPEC"};
# global variables (modified by options)
-my $what = 0;
+my $what = "";
my @whatArray;
my $force_win = 0;
my $check_includes = 0;
@@ -83,7 +83,7 @@ sub showUsage
print "$0 usage:\n";
print " -windows Force platform to Windows (default: " . ($force_win ? "yes" : "no") . ")\n";
print " -outdir <PATH> Specify output directory for sync (default: $out_basedir)\n";
- print " -what Output what files would be synced (default: " . ($what ? "yes" : "no") . ")\n";
+ print " -what <whatlog file> Output what files were synced (default: $what)\n";
print " -help This help\n";
exit 0;
}
@@ -310,12 +310,7 @@ sub syncHeader {
my ($header, $iheader, $copy) = @_;
$iheader =~ s=\\=/=g;
$header =~ s=\\=/=g;
-
- if ($what) {
- push(@whatArray, $header);
- return 1;
- }
-
+ push(@whatArray, $header);
return copyFile($iheader, $header) if($copy);
unless(-e $header) {
@@ -512,8 +507,11 @@ while ( @ARGV ) {
} elsif($arg eq "-o" || $arg eq "-outdir") {
$var = "output";
$val = shift @ARGV;
+ } elsif($arg eq "-what") {
+ $var = "what";
+ $val = shift @ARGV;
} elsif($arg eq "-showonly" || $arg eq "-remove-stale" || $arg eq "-windows" ||
- $arg eq "-relative" || $arg eq "-check-includes" || $arg eq "-what") {
+ $arg eq "-relative" || $arg eq "-check-includes") {
$var = substr($arg, 1);
$val = "yes";
} elsif($arg =~ /^-no-(.*)$/) {
@@ -534,11 +532,7 @@ while ( @ARGV ) {
print "Unknown option: $arg\n\n" if(!$var);
showUsage();
} elsif ($var eq "what") {
- if ($val eq "yes") {
- $what++;
- } elsif ($what) {
- $what--;
- }
+ $what = $val;
} elsif ($var eq "check-includes") {
if($val eq "yes") {
$check_includes++;
@@ -568,11 +562,9 @@ while ( @ARGV ) {
$isunix = checkUnix; #cache checkUnix
-if (!$what) {
- # create path
- mkpath "$out_basedir/include";
- mkpath "$out_basedir/mw/Qt";
-}
+# create path
+mkpath "$out_basedir/include";
+mkpath "$out_basedir/mw/Qt";
my @ignore_headers = ();
my $class_lib_map_contents = "";
@@ -716,31 +708,27 @@ foreach my $lib (@modules_to_sync) {
# write forwarding headers to include/Qt
if ($lib ne "phonon" && $subdir =~ /^$basedir\/src/) {
my $file_name = "$out_basedir/mw/Qt/$header";
- if ($what) {
- push(@whatArray, $file_name);
+ push(@whatArray, $file_name);
+ my $file_op = '>';
+ my $header_content = '';
+ if (exists $colliding_headers{$file_name}) {
+ $file_op = '>>';
} else {
- my $file_op = '>';
- my $header_content = '';
- if (exists $colliding_headers{$file_name}) {
- $file_op = '>>';
- } else {
- $colliding_headers{$file_name} = 1;
- my $warning_msg = 'Inclusion of header files from include/Qt is deprecated.';
- $header_content = "#ifndef QT_NO_QT_INCLUDE_WARN\n" .
- " #if defined(__GNUC__)\n" .
- " #warning \"$warning_msg\"\n" .
- " #elif defined(_MSC_VER)\n" .
- " #pragma message(\"WARNING: $warning_msg\")\n" .
- " #endif\n".
- "#endif\n\n";
- }
- $header_content .= '#include "' . "../$lib/$header" . "\"\n";
- open HEADERFILE, $file_op, $file_name or die "unable to open '$file_name' : $!\n";
- print HEADERFILE $header_content;
- close HEADERFILE;
+ $colliding_headers{$file_name} = 1;
+ my $warning_msg = 'Inclusion of header files from include/Qt is deprecated.';
+ $header_content = "#ifndef QT_NO_QT_INCLUDE_WARN\n" .
+ " #if defined(__GNUC__)\n" .
+ " #warning \"$warning_msg\"\n" .
+ " #elif defined(_MSC_VER)\n" .
+ " #pragma message(\"WARNING: $warning_msg\")\n" .
+ " #endif\n".
+ "#endif\n\n";
}
+ $header_content .= '#include "' . "../$lib/$header" . "\"\n";
+ open HEADERFILE, $file_op, $file_name or die "unable to open '$file_name' : $!\n";
+ print HEADERFILE $header_content;
+ close HEADERFILE;
}
-
foreach my $full_class (@classes) {
my $header_base = basename($header);
# Strip namespaces:
@@ -789,7 +777,7 @@ foreach my $lib (@modules_to_sync) {
my $pri_install_iheader = fixPaths($iheader, $current_dir);
$pri_install_pfiles.= "$pri_install_iheader ";;
}
- print "header created for $iheader ($header_copies)\n" if($header_copies > 0 && !$what);
+ print "header created for $iheader ($header_copies)\n" if($header_copies > 0);
}
}
}
@@ -805,6 +793,7 @@ foreach my $lib (@modules_to_sync) {
#generate the "master" include file
my @tmp = split(/;/,$modules{$lib});
$pri_install_files .= fixPaths($master_include, $tmp[0]) . " "; #get the master file installed too
+ push(@whatArray, $master_include) if ($master_contents);
if($master_include && -e $master_include) {
open MASTERINCLUDE, "<$master_include";
local $/;
@@ -812,19 +801,15 @@ foreach my $lib (@modules_to_sync) {
my $oldmaster = <MASTERINCLUDE>;
close MASTERINCLUDE;
$oldmaster =~ s/\r//g; # remove \r's , so comparison is ok on all platforms
- $master_include = 0 if($oldmaster eq $master_contents && !$what);
+ $master_include = 0 if($oldmaster eq $master_contents);
}
if($master_include && $master_contents) {
- if ($what) {
- push(@whatArray, $master_include);
- } else {
- my $master_dir = dirname($master_include);
- mkpath $master_dir;
- print "header (master) created for $lib\n";
- open MASTERINCLUDE, ">$master_include";
- print MASTERINCLUDE $master_contents;
- close MASTERINCLUDE;
- }
+ my $master_dir = dirname($master_include);
+ mkpath $master_dir;
+ print "header (master) created for $lib\n";
+ open MASTERINCLUDE, ">$master_include";
+ print MASTERINCLUDE $master_contents;
+ close MASTERINCLUDE;
}
}
@@ -834,6 +819,7 @@ foreach my $lib (@modules_to_sync) {
$headers_pri_contents .= "SYNCQT.HEADER_CLASSES = $pri_install_classes\n";
$headers_pri_contents .= "SYNCQT.PRIVATE_HEADER_FILES = $pri_install_pfiles\n";
my $headers_pri_file = "$out_basedir/mw/$lib/headers.pri";
+ push(@whatArray, $headers_pri_file) if ($master_contents);
if(-e $headers_pri_file) {
open HEADERS_PRI_FILE, "<$headers_pri_file";
local $/;
@@ -841,23 +827,20 @@ foreach my $lib (@modules_to_sync) {
my $old_headers_pri_contents = <HEADERS_PRI_FILE>;
close HEADERS_PRI_FILE;
$old_headers_pri_contents =~ s/\r//g; # remove \r's , so comparison is ok on all platforms
- $headers_pri_file = 0 if($old_headers_pri_contents eq $headers_pri_contents && !$what);
+ $headers_pri_file = 0 if($old_headers_pri_contents eq $headers_pri_contents);
}
if($headers_pri_file && $master_contents) {
- if ($what) {
- push(@whatArray, $headers_pri_file);
- } else {
- my $headers_pri_dir = dirname($headers_pri_file);
- mkpath $headers_pri_dir;
- print "headers.pri file created for $lib\n";
- open HEADERS_PRI_FILE, ">$headers_pri_file";
- print HEADERS_PRI_FILE $headers_pri_contents;
- close HEADERS_PRI_FILE;
- }
+ my $headers_pri_dir = dirname($headers_pri_file);
+ mkpath $headers_pri_dir;
+ print "headers.pri file created for $lib\n";
+ open HEADERS_PRI_FILE, ">$headers_pri_file";
+ print HEADERS_PRI_FILE $headers_pri_contents;
+ close HEADERS_PRI_FILE;
}
}
unless(!$create_uic_class_map) {
my $class_lib_map = "$out_basedir/src/tools/uic/qclass_lib_map.h";
+ push(@whatArray, $class_lib_map);
if(-e $class_lib_map) {
open CLASS_LIB_MAP, "<$class_lib_map";
local $/;
@@ -865,18 +848,14 @@ unless(!$create_uic_class_map) {
my $old_class_lib_map_contents = <CLASS_LIB_MAP>;
close CLASS_LIB_MAP;
$old_class_lib_map_contents =~ s/\r//g; # remove \r's , so comparison is ok on all platforms
- $class_lib_map = 0 if($old_class_lib_map_contents eq $class_lib_map_contents && !$what);
+ $class_lib_map = 0 if($old_class_lib_map_contents eq $class_lib_map_contents);
}
if($class_lib_map) {
- if ($what) {
- push(@whatArray, $class_lib_map);
- } else {
- my $class_lib_map_dir = dirname($class_lib_map);
- mkpath $class_lib_map_dir;
- open CLASS_LIB_MAP, ">$class_lib_map";
- print CLASS_LIB_MAP $class_lib_map_contents;
- close CLASS_LIB_MAP;
- }
+ my $class_lib_map_dir = dirname($class_lib_map);
+ mkpath $class_lib_map_dir;
+ open CLASS_LIB_MAP, ">$class_lib_map";
+ print CLASS_LIB_MAP $class_lib_map_contents;
+ close CLASS_LIB_MAP;
}
}
@@ -1012,12 +991,15 @@ if ($what) {
my @sortedWhat = sort(@whatArray);
my $whatItem;
my $previousWhatItem = "";
- foreach $whatItem (@sortedWhat) {
- if ($previousWhatItem ne $whatItem) {
- $previousWhatItem = $whatItem;
- $whatItem =~ s=//=/=g;
- print "$whatItem\n" ;
+ if (open(OUTPUT, ">$what")) {
+ foreach $whatItem (@sortedWhat) {
+ if ($previousWhatItem ne $whatItem) {
+ $previousWhatItem = $whatItem;
+ $whatItem =~ s=//=/=g;
+ print OUTPUT "$whatItem\n" ;
+ }
}
+ close(OUTPUT);
}
}
diff --git a/config.profiles/symbian/qtconfig.flm b/config.profiles/symbian/qtconfig.flm
index 94f732a..9075164 100644
--- a/config.profiles/symbian/qtconfig.flm
+++ b/config.profiles/symbian/qtconfig.flm
@@ -60,31 +60,25 @@ $(SOURCEDIR)/qmake$(DOTEXE): $(EXTENSION_ROOT)/$(QT_ROOT)/$(CONFIGURE_APP)
$(call endrule,qtconf)
$(call startrule,headerexport) \
cd $(EXTENSION_ROOT)/$(QT_ROOT)/config.profiles/symbian && \
- perl headerexport -base-dir $(EXTENSION_ROOT)/$(QT_ROOT) -outdir $(EPOCROOT)/epoc32/include/
+ perl headerexport -base-dir $(EXTENSION_ROOT)/$(QT_ROOT) -outdir $(EPOCROOT)/epoc32/include/ -what $(SOURCEDIR)/qtconfig_what.log
$(call endrule,headerexport)
$(call startrule,mkspecexport) \
$(GNUCP) -R $(EXTENSION_ROOT)/$(QT_ROOT)/mkspecs $(MKSPECDIR)
+ $(GNUFIND) $(EXTENSION_ROOT)/$(QT_ROOT)/mkspecs -type f | \
+ $(GNUSED) 's!$(EXTENSION_ROOT)/$(QT_ROOT)/!$(MKSPECDIR)/!' >> $(SOURCEDIR)/qtconfig_what.log \
$(call endrule,mkspecexport)
FINAL WHAT:: $(SOURCEDIR)/qmake$(DOTEXE)
$(call startrawoutput) \
echo "$(call whatLogOpen)"; \
- cd $(EXTENSION_ROOT)/$(QT_ROOT)/config.profiles/symbian && \
- perl headerexport -base-dir $(EXTENSION_ROOT)/$(QT_ROOT) -outdir $(EPOCROOT)/epoc32/include/ -what | \
+ $(GNUCAT) $(SOURCEDIR)/qtconfig_what.log | \
(read -r LINE; \
while [ $$$$? -eq 0 ]; do \
echo "$(call whatLogItem,,$$$$LINE)"; \
read -r LINE; \
done; \
); \
- $(GNUFIND) $(EXTENSION_ROOT)/$(QT_ROOT)/mkspecs -type f | \
- (read -r LINE; \
- while [ $$$$? -eq 0 ]; do \
- echo "$(call whatLogItem,,$$$$LINE)" | $(GNUSED) 's#$(EXTENSION_ROOT)/$(QT_ROOT)#$(MKSPECDIR)#'; \
- read -r LINE; \
- done; \
- ); \
- echo "$(call whatLogClose)"; \
+ echo "$(call whatLogClose)" \
$(call endrawoutput)
endef
@@ -100,10 +94,11 @@ else
EXPORT:: $(TARGET_TOOLS)
endif
$(eval $(call QtConfiguration))
-$(eval $(call whatmacro,$(TARGET_TOOLS)))
ifeq ($(OSTYPE),unix)
+$(eval $(call whatmacro,$(QT_TOOLS) $(TARGET_TOOLS)))
$(eval $(call GenerateStandardCleanTarget,$(QT_TOOLS) $(TARGET_TOOLS) $(SOURCE_TOOLS),$(TARGETDIR)))
else
+$(eval $(call whatmacro,$(TARGET_TOOLS)))
$(eval $(call GenerateStandardCleanTarget,$(TARGET_TOOLS) $(SOURCE_TOOLS),$(TARGETDIR)))
endif
endif