office-gobmx/solenv/clang-format/check-last-commit
Ilmari Lauhakangas 0fcc2f933e Revert "check-last-commit: more detailed advice on using clang-format"
This reverts commit f59d449ecf.

Reason for revert: confusing

Change-Id: If5924ff3952f344f7a418e80d4ceb774dea94430
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/146707
Tested-by: Ilmari Lauhakangas <ilmari.lauhakangas@libreoffice.org>
Reviewed-by: Ilmari Lauhakangas <ilmari.lauhakangas@libreoffice.org>
2023-02-10 08:12:26 +00:00

98 lines
2.9 KiB
Perl
Executable file

#!/usr/bin/env perl
# This file is part of the LibreOffice project.
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
# Checks the style of the files changed in the last commit, for CI purposes.
use strict;
use warnings;
use lib "solenv/clang-format";
use ClangFormat;
my $commit = 0;
my $commit_id = 'HEAD';
sub check_style()
{
if ( ! -e ".git" )
{
# Can't diff when this is not a git checkout.
return;
}
my $src = ClangFormat::get_extension_regex();
my @good_names = ();
my @bad_names = ();
my $excluded_list_names = ClangFormat::get_excludelist();
my $clang_format = ClangFormat::find();
my $parent = $commit + 1;
# Get a list of non-deleted changed files.
# Explicitly use the low-level 'git diff-tree' (rather than plain 'git
# diff') so we get the new, but not the old files for renames and/or
# copies.
open (FILES, "git diff-tree -r --diff-filter=AM --name-only ${commit_id}~${parent} ${commit_id}~${commit} |") || die "Cannot run git diff.";
while (my $filename = <FILES>)
{
chomp $filename;
if ($filename =~ /\.($src)$/ and !exists($excluded_list_names->{$filename}))
{
if (! -x $clang_format)
{
my $version = ClangFormat::get_wanted_version();
print("solenv/clang-format/check-last-commit: ");
print("ERROR: no clang-format ${version} was found.\n\n");
exit(1);
}
if (ClangFormat::check_style($clang_format, $filename))
{
push @good_names, $filename;
}
else
{
push @bad_names, $filename;
}
}
}
# Enforce style.
if (scalar @bad_names)
{
print("\nERROR: The above differences were found between the code to commit \n");
print("and the clang-format rules. Tips:\n");
print("\n- You may run '/opt/lo/bin/clang-format -i <problematic file>' to fix up style automatically.\n");
print("- See solenv/clang-format/README on where to get the required version of clang-format binaries.\n");
print("- If you renamed an excluded file, update solenv/clang-format/excludelist accordingly to keep it excluded.\n");
print("\nsolenv/clang-format/check-last-commit: KO\n");
exit(1);
}
else
{
print("solenv/clang-format/check-last-commit: checked the following files:\n");
print(join("\n", @good_names));
print("\nsolenv/clang-format/check-last-commit: OK\n");
}
}
if (scalar(@ARGV) == 1)
{
if (($ARGV[0] !~ /^[0-9]+$/) || (scalar($ARGV[0]) >= 8))
{
$commit_id = $ARGV[0];
}
else
{
$commit = $ARGV[0];
}
}
check_style();
exit(0);
# vim: set shiftwidth=4 softtabstop=4 expandtab: