On 12/06/18 11:03, Tom de Vries wrote:
> [ 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?
OK.
R.
>>
>> 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
>