[ Fixed ENOPATCH ]
On Tue, Jun 12, 2018 at 11:57:13AM +0200, Tom de Vries wrote:
> [ was: Re: [MAINTAINERS, committed] Remove redundant write-after-approval
> entries ]
>
> On Tue, Jun 12, 2018 at 10:26:31AM +0200, Martin Liška wrote:
> > Hi.
> >
> > Thanks for the script, it also found me in Write After Approval section.
> > Thus I'll install following patch.
> >
> > Tom what about installing the script into contrib?
>
> I've renamed the script to contrib/maintainers-verify.sh.
>
> Also I've added a regression test that runs it:
> ...
> Running src/gcc/testsuite/gcc.src/maintainers.exp ...
> PASS: maintainers-verify.sh
> ...
>
> When failing (by reverting your patch on MAINTAINERS), it shows in gcc.log:
> ...
> Running src/gcc/testsuite/gcc.src/maintainers.exp ...
> Redundant in write approval: Martin Liska
> FAIL: maintainers-verify.sh
> ...
>
> OK for trunk?
>
> Thanks,
> - Tom
[contrib] Add contrib/maintainers-verify.sh
---
contrib/maintainers-verify.sh | 45 +++++++++++++++++++++++++++++++++++
gcc/testsuite/gcc.src/maintainers.exp | 35 +++++++++++++++++++++++++++
2 files changed, 80 insertions(+)
diff --git a/contrib/maintainers-verify.sh b/contrib/maintainers-verify.sh
new file mode 100755
index 00000000000..226c158fdaa
--- /dev/null
+++ b/contrib/maintainers-verify.sh
@@ -0,0 +1,45 @@
+#!/bin/sh
+
+# Copyright (C) 2018 Free Software Foundation, Inc.
+#
+# This file is part of GCC.
+#
+# GCC is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3, or (at your option)
+# any later version.
+#
+# GCC 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 for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with GCC; see the file COPYING. If not, write to
+# the Free Software Foundation, 51 Franklin Street, Fifth Floor,
+# Boston, MA 02110-1301, USA.
+
+if [ "$1" != "" ]; then
+ f="$1"
+else
+ f=./MAINTAINERS
+fi
+
+grep @ $f \
+ | sed 's/[\t][\t]*/\t/g' \
+ | awk -F '\t' \
+ "
+{
+ if (NF == 2) {
+ name=\$1
+ email=\$2
+ if (names[name] == 1) {
+ printf \"Redundant in write approval: %s\n\", name
+ }
+ } else if (NF == 3 ) {
+ name=\$2
+ email=\$3
+ names[name] = 1
+ }
+}
+"
diff --git a/gcc/testsuite/gcc.src/maintainers.exp
b/gcc/testsuite/gcc.src/maintainers.exp
new file mode 100644
index 00000000000..89a062fb7ad
--- /dev/null
+++ b/gcc/testsuite/gcc.src/maintainers.exp
@@ -0,0 +1,35 @@
+# Copyright (C) 2018 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program 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 for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with GCC; see the file COPYING3. If not see
+# <http://www.gnu.org/licenses/>.
+
+proc gcc_src_run_maintainers_verify_sh {} {
+ set script maintainers-verify.sh
+
+ global srcdir
+ set rootdir $srcdir/../..
+ set contrib $rootdir/contrib
+
+ set maintainers $rootdir/MAINTAINERS
+
+ set verify_output [exec $contrib/$script $maintainers]
+ if { "$verify_output" == "" } {
+ pass "$script"
+ } else {
+ send_log "$verify_output\n"
+ fail "$script"
+ }
+}
+
+gcc_src_run_maintainers_verify_sh