Replace fixqt4headers shell script
Use a perl script with a slightly better scalability. No more quadratic behavior, takes about 10 seconds (instead of 5 hours) on my machine to fix all QtCreator headers Change-Id: Ic7d00c28aec390a1da27a969ece5d8102674e919 Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
parent
4d85540bdb
commit
f02c2389ee
@ -1,23 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
modules=`ls $QTDIR/include`
|
||||
|
||||
files=`find * -name '*.h' -or -name '*.cpp' -or -name '*.C' -or -name '*.cc' -or -name '*.CC'`
|
||||
|
||||
echo $files
|
||||
|
||||
for module in $modules; do
|
||||
# once we change other things, change the line from == "QtWidgets" to != "Qt" to get everything fixed
|
||||
if [ $module == "QtWidgets" ] || [ $module == "QtPrintSupport" ]; then
|
||||
echo $module ":"
|
||||
includes=`ls $QTDIR/include/$module`
|
||||
for i in $includes; do
|
||||
# echo " fixing " $i
|
||||
perl -pi -e "s,^#(\\s*)include(\\s+)<.+?/$i>,#\\1include\\2<$module/$i>," $files;
|
||||
# perl -pi -e 's,^#include +".+/$i",#include "$module/$i",' $files;
|
||||
done;
|
||||
fi;
|
||||
done;
|
||||
|
||||
perl -pi -e 's,<QtGui>,<QtWidgets>,' $files
|
||||
perl -pi -e 's,<QtGui/QtGui>,<QtWidgets/QtWidgets>,' $files
|
195
bin/fixqt4headers.pl
Executable file
195
bin/fixqt4headers.pl
Executable file
@ -0,0 +1,195 @@
|
||||
#!/usr/bin/env perl
|
||||
#############################################################################
|
||||
##
|
||||
## Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
|
||||
## All rights reserved.
|
||||
## Contact: Nokia Corporation (qt-info@nokia.com)
|
||||
##
|
||||
## This file is part of the porting tools of the Qt Toolkit.
|
||||
##
|
||||
## $QT_BEGIN_LICENSE:LGPL$
|
||||
## GNU Lesser General Public License Usage
|
||||
## This file may be used under the terms of the GNU Lesser General Public
|
||||
## License version 2.1 as published by the Free Software Foundation and
|
||||
## appearing in the file LICENSE.LGPL included in the packaging of this
|
||||
## file. Please review the following information to ensure the GNU Lesser
|
||||
## General Public License version 2.1 requirements will be met:
|
||||
## http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
||||
##
|
||||
## In addition, as a special exception, Nokia gives you certain additional
|
||||
## rights. These rights are described in the Nokia Qt LGPL Exception
|
||||
## version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
||||
##
|
||||
## GNU General Public License Usage
|
||||
## Alternatively, this file may be used under the terms of the GNU General
|
||||
## Public License version 3.0 as published by the Free Software Foundation
|
||||
## and appearing in the file LICENSE.GPL included in the packaging of this
|
||||
## file. Please review the following information to ensure the GNU General
|
||||
## Public License version 3.0 requirements will be met:
|
||||
## http://www.gnu.org/copyleft/gpl.html.
|
||||
##
|
||||
## Other Usage
|
||||
## Alternatively, this file may be used in accordance with the terms and
|
||||
## conditions contained in a signed written agreement between you and Nokia.
|
||||
##
|
||||
##
|
||||
##
|
||||
##
|
||||
##
|
||||
## $QT_END_LICENSE$
|
||||
##
|
||||
#############################################################################
|
||||
|
||||
|
||||
use Cwd;
|
||||
use File::Find;
|
||||
use File::Spec;
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
my $dry_run = 0;
|
||||
my $fixedFileCount = 0;
|
||||
|
||||
sub show_help
|
||||
{
|
||||
print "This script replaces all Qt 4 style includes with Qt 5 includes\n";
|
||||
print "\n";
|
||||
print "Usage: $0 [--dry-run]\n";
|
||||
print "\n";
|
||||
print " --dry-run : Do not replace anything, just print what would be replaced\n";
|
||||
print "\n";
|
||||
}
|
||||
|
||||
if ($#ARGV >= 0) {
|
||||
if ($#ARGV >= 1) {
|
||||
die "$0: Takes only one or zero arguments\n";
|
||||
} elsif ($ARGV[0] eq "--dry-run") {
|
||||
$dry_run = 1;
|
||||
} elsif ($ARGV[0] eq "--help") {
|
||||
show_help();
|
||||
exit 0
|
||||
} else {
|
||||
show_help();
|
||||
print "Unknown argument: $ARGV[0]\n";
|
||||
exit 1;
|
||||
}
|
||||
}
|
||||
|
||||
my %headerSubst = ();
|
||||
my $qtdir;
|
||||
my $cwd = getcwd();
|
||||
|
||||
sub fixHeaders
|
||||
{
|
||||
my $fileName = $File::Find::name;
|
||||
my $relFileName = File::Spec->abs2rel($fileName, $cwd);
|
||||
|
||||
# only check sources, also ignore symbolic links and directories
|
||||
if ($fileName !~ /(\.h|\.cpp|\/C|\.cc|\.CC)$/ || ! -f $fileName) {
|
||||
return;
|
||||
}
|
||||
|
||||
open IN, "<", $fileName || die "Unable to open \"$fileName\": $!\n";
|
||||
|
||||
my $found = 0;
|
||||
|
||||
# First, we check whether we have a match
|
||||
while (<IN>) {
|
||||
my $line = $_;
|
||||
|
||||
if ($line =~ /^#\s*include\s*<(.*?\/(.*?))>/) {
|
||||
my $newHeader = $headerSubst{$2};
|
||||
if ($newHeader && $1 ne $newHeader) {
|
||||
if ($dry_run) {
|
||||
print "$relFileName: <$1> => <$newHeader>\n";
|
||||
} else {
|
||||
$found = 1;
|
||||
last;
|
||||
}
|
||||
}
|
||||
} elsif ($line =~ /^#\s*include\s*<QtGui>/) {
|
||||
if ($dry_run) {
|
||||
print "$relFileName: <QtGui> => <QtWidgets>\n";
|
||||
} else {
|
||||
$found = 1;
|
||||
last;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if ($dry_run || !$found) {
|
||||
return;
|
||||
}
|
||||
|
||||
# rewind to top
|
||||
seek(IN, 0, 0) || die "Unable to seek in $fileName: $!\n";
|
||||
|
||||
open OUT, ">", "$fileName.new" || die "Unable to open \"$fileName.new\": $!\n";
|
||||
|
||||
while (<IN>) {
|
||||
my $line = $_;
|
||||
if ($line =~ /^#(\s*)include(\s*)<.*?\/(.*?)>(.*)/) {
|
||||
my $newHeader = $headerSubst{$3};
|
||||
if ($newHeader) {
|
||||
$line = "#$1include$2<$newHeader>$4\n";
|
||||
}
|
||||
} elsif ($line =~ /^#(\s*)include(\s*)<QtGui>(.*)/) {
|
||||
$line = "#$1include$2<QtWidgets>$3\n";
|
||||
}
|
||||
|
||||
print OUT $line;
|
||||
}
|
||||
|
||||
close OUT;
|
||||
|
||||
close IN;
|
||||
|
||||
rename "$fileName.new", $fileName || die "Unable to move $fileName.new to $fileName: $!\n";
|
||||
|
||||
$fixedFileCount += 1;
|
||||
}
|
||||
|
||||
sub findQtHeaders
|
||||
{
|
||||
my ($dirName,$baseDir) = @_;
|
||||
|
||||
local (*DIR);
|
||||
|
||||
opendir(DIR, "$baseDir/include/$dirName") || die "Unable to open \"$baseDir/include/$dirName\": $!\n";
|
||||
my @headers = readdir(DIR);
|
||||
closedir(DIR);
|
||||
|
||||
foreach my $header (@headers) {
|
||||
if (-d "$baseDir/include/$dirName/$header" || $header =~ /\.pri$/) {
|
||||
next;
|
||||
}
|
||||
$headerSubst{$header} = "$dirName/$header";
|
||||
}
|
||||
}
|
||||
|
||||
$qtdir = $ENV{'QTDIR'};
|
||||
|
||||
if (!$qtdir) {
|
||||
die "This script requires the QTDIR environment variable pointing to Qt 5\n";
|
||||
}
|
||||
|
||||
findQtHeaders("QtWidgets", $qtdir);
|
||||
findQtHeaders("QtPrintSupport", $qtdir);
|
||||
|
||||
if (-d "$qtdir/include/QtQuick1") {
|
||||
findQtHeaders("QtQuick1", $qtdir);
|
||||
} elsif (-d "$qtdir/../qtdeclarative" ) {
|
||||
# This is the case if QTDIR points to a source tree instead of an installed Qt
|
||||
findQtHeaders("QtQuick1", "$qtdir/../qtdeclarative");
|
||||
} else {
|
||||
print "Warning - cannot find QtQuick1 headers\n";
|
||||
}
|
||||
|
||||
# special case
|
||||
$headerSubst{"QtGui"} = "QtWidgets/QtWidgets";
|
||||
|
||||
find({ wanted => \&fixHeaders, no_chdir => 1}, $cwd);
|
||||
|
||||
if ($dry_run == 0) {
|
||||
print "Done. Modified $fixedFileCount file(s).\n";
|
||||
}
|
Loading…
Reference in New Issue
Block a user