On Wed, 28 Feb 2024, Ken Matsui wrote:

> This patch implements a --num-commits (-n) flag for shorthand for
> the range of hash~N..hash commits.
> 
> contrib/ChangeLog:
> 
>       * gcc-changelog/git_check_commit.py: Implement --num-commits.

LGTM

> 
> Signed-off-by: Ken Matsui <kmat...@gcc.gnu.org>
> ---
>  contrib/gcc-changelog/git_check_commit.py | 15 +++++++++++++++
>  1 file changed, 15 insertions(+)
> 
> diff --git a/contrib/gcc-changelog/git_check_commit.py 
> b/contrib/gcc-changelog/git_check_commit.py
> index 8cca9f439a5..22e032e8b38 100755
> --- a/contrib/gcc-changelog/git_check_commit.py
> +++ b/contrib/gcc-changelog/git_check_commit.py
> @@ -22,6 +22,12 @@ import argparse
>  
>  from git_repository import parse_git_revisions
>  
> +def nonzero_uint(value):
> +    ivalue = int(value)
> +    if ivalue <= 0:
> +        raise argparse.ArgumentTypeError('%s is not a non-zero positive 
> integer' % value)
> +    return ivalue
> +
>  parser = argparse.ArgumentParser(description='Check git ChangeLog format '
>                                   'of a commit')
>  parser.add_argument('revisions', default='HEAD', nargs='?',
> @@ -33,8 +39,17 @@ parser.add_argument('-p', '--print-changelog', 
> action='store_true',
>                      help='Print final changelog entires')
>  parser.add_argument('-v', '--verbose', action='store_true',
>                      help='Print verbose information')
> +parser.add_argument('-n', '--num-commits', type=nonzero_uint, default=1,
> +                    help='Number of commits to check (i.e. shorthand for '
> +                    'hash~N..hash)')
>  args = parser.parse_args()
>  
> +if args.num_commits > 1:
> +    if '..' in args.revisions:
> +        print('ERR: --num-commits and range of revisions are mutually 
> exclusive')
> +        exit(1)
> +    args.revisions = '{0}~{1}..{0}'.format(args.revisions, args.num_commits)
> +
>  retval = 0
>  for git_commit in parse_git_revisions(args.git_path, args.revisions):
>      res = 'OK' if git_commit.success else 'FAILED'
> -- 
> 2.44.0
> 
> 

Reply via email to