209 lines
4.7 KiB
Perl
209 lines
4.7 KiB
Perl
|
#!/usr/bin/perl
|
||
|
|
||
|
#
|
||
|
# Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved.
|
||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||
|
#
|
||
|
# This code is free software; you can redistribute it and/or modify it
|
||
|
# under the terms of the GNU General Public License version 2 only, as
|
||
|
# published by the Free Software Foundation.
|
||
|
#
|
||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||
|
# accompanied this code).
|
||
|
#
|
||
|
# You should have received a copy of the GNU General Public License version
|
||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||
|
#
|
||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||
|
# or visit www.oracle.com if you need additional information or have any
|
||
|
# questions.
|
||
|
#
|
||
|
|
||
|
#
|
||
|
# Parses java files:
|
||
|
# 1. Removes from the end of lines spaces and TABs
|
||
|
# 2. Replaces TABs by spaces
|
||
|
# 3. Replaces all NewLine separators by Unix NewLine separators
|
||
|
# 4. Makes one and only one empty line at the end of each file
|
||
|
|
||
|
if ($#ARGV < 0) {
|
||
|
&usage;
|
||
|
|
||
|
die;
|
||
|
}
|
||
|
|
||
|
use Cwd 'abs_path';
|
||
|
|
||
|
my @extensions = ("java");
|
||
|
|
||
|
# Read options
|
||
|
my $dirpos = 0;
|
||
|
|
||
|
while ($dirpos < $#ARGV) {
|
||
|
if ($ARGV[$dirpos] eq "-e") {
|
||
|
@extensions = split(/,/, $ARGV[$dirpos + 1]);
|
||
|
} else {
|
||
|
last;
|
||
|
}
|
||
|
|
||
|
$dirpos += 2;
|
||
|
}
|
||
|
|
||
|
if ($dirpos > $#ARGV) {
|
||
|
&usage;
|
||
|
|
||
|
die;
|
||
|
}
|
||
|
|
||
|
use Cwd;
|
||
|
my $currdir = getcwd;
|
||
|
|
||
|
my $allfiles = 0;
|
||
|
|
||
|
my $filecount = 0;
|
||
|
|
||
|
my @tabvalues;
|
||
|
|
||
|
# Init tabvalues
|
||
|
push (@tabvalues, " ");
|
||
|
|
||
|
for (my $i = 1; $i < 8; $i++) {
|
||
|
push(@tabvalues, $tabvalues[$i - 1] . " ");
|
||
|
}
|
||
|
|
||
|
open(FILELIST, ">$currdir/filelist") or die "Failed while open $currdir/filelist: $!\n";
|
||
|
|
||
|
while ($dirpos <= $#ARGV) {
|
||
|
use File::Find;
|
||
|
|
||
|
find(\&parse_file, abs_path($ARGV[$dirpos]));
|
||
|
|
||
|
$dirpos += 1;
|
||
|
}
|
||
|
|
||
|
close(FILELIST);
|
||
|
|
||
|
use Cwd 'chdir';
|
||
|
chdir $currdir;
|
||
|
|
||
|
print "Checked $allfiles file(s)\n";
|
||
|
print "Modified $filecount file(s)\n";
|
||
|
print "See results in the file $currdir/filelist\n";
|
||
|
|
||
|
sub parse_file {
|
||
|
my $filename = $File::Find::name;
|
||
|
|
||
|
# Skip directories
|
||
|
return if -d;
|
||
|
|
||
|
# Skip SCCS files
|
||
|
return if ($filename =~ /\/SCCS\//);
|
||
|
|
||
|
# Skip files with invalid extensions
|
||
|
my $accepted = 0;
|
||
|
foreach my $ext (@extensions) {
|
||
|
if ($_ =~ /\.$ext$/i) {
|
||
|
$accepted = 1;
|
||
|
|
||
|
last;
|
||
|
}
|
||
|
}
|
||
|
return if ($accepted == 0);
|
||
|
|
||
|
use File::Basename;
|
||
|
my $dirname = dirname($filename);
|
||
|
|
||
|
use Cwd 'chdir';
|
||
|
chdir $dirname;
|
||
|
|
||
|
open(FILE, $filename) or die "Failed while open $filename: $!\n";
|
||
|
|
||
|
# Read file
|
||
|
my @content;
|
||
|
my $line;
|
||
|
my $emptylinescount = 0;
|
||
|
my $modified = 0;
|
||
|
|
||
|
while ($line = <FILE>) {
|
||
|
my $originalline = $line;
|
||
|
|
||
|
# Process line
|
||
|
|
||
|
# Remove from the end of the line spaces and return character
|
||
|
while ($line =~ /\s$/) {
|
||
|
chop($line);
|
||
|
}
|
||
|
|
||
|
# Replace TABs
|
||
|
for (my $i = 0; $i < length($line); $i++) {
|
||
|
if (substr($line, $i, 1) =~ /\t/) {
|
||
|
$line = substr($line, 0, $i) . $tabvalues[7 - ($i % 8)] . substr($line, $i + 1);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (length($line) == 0) {
|
||
|
$emptylinescount++;
|
||
|
} else {
|
||
|
while ($emptylinescount > 0) {
|
||
|
push(@content, "");
|
||
|
|
||
|
$emptylinescount--;
|
||
|
}
|
||
|
|
||
|
push(@content, $line);
|
||
|
}
|
||
|
|
||
|
if ($originalline ne ($line . "\n")) {
|
||
|
$modified = 1;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
$allfiles++;
|
||
|
|
||
|
if ($emptylinescount > 0) {
|
||
|
$modified = 1;
|
||
|
}
|
||
|
|
||
|
close(FILE);
|
||
|
|
||
|
if ($modified != 0) {
|
||
|
# Write file
|
||
|
open(FILE, ">$filename") or die "Failed while open $filename: $!\n";
|
||
|
|
||
|
for (my $i = 0; $i <= $#content; $i++) {
|
||
|
print FILE "$content[$i]\n";
|
||
|
}
|
||
|
|
||
|
close(FILE);
|
||
|
|
||
|
# Print name from current dir
|
||
|
if (index($filename, $currdir) == 0) {
|
||
|
print FILELIST substr($filename, length($currdir) + 1);
|
||
|
} else {
|
||
|
print FILELIST $filename;
|
||
|
}
|
||
|
print FILELIST "\n";
|
||
|
|
||
|
$filecount++;
|
||
|
|
||
|
print "$filename: modified\n";
|
||
|
}
|
||
|
}
|
||
|
|
||
|
sub usage {
|
||
|
print "Usage:\n";
|
||
|
print " normalizer.pl [-options] <dir> [dir2 dir3 ...]\n";
|
||
|
print " Available options:\n";
|
||
|
print " -e comma separated files extensions. By default accepts only java files\n";
|
||
|
print "\n";
|
||
|
print "Examples:\n";
|
||
|
print " normalizer.pl -e c,cpp,h,hpp .\n";
|
||
|
}
|
||
|
|
||
|
|