Re: [PATCH] get_maintainer: Add the --for-tree argument

From: Joe Perches
Date: Thu Oct 13 2022 - 20:40:05 EST


On Thu, 2022-10-13 at 14:57 -0700, Palmer Dabbelt wrote:
> I recently wanted to look up the maintainers for each tree path via a
> script, and I couldn't find a better way to do that than poking
> get_maintainer.pl to add a new argument. This lets folks run something
> like
>
> $ ./scripts/get_maintainer.pl --for-tree git://github.com/kvm-riscv/linux.git
> Anup Patel <anup@xxxxxxxxxxxxxx> (maintainer:KERNEL VIRTUAL MACHINE FOR RISC-V (KVM/riscv))
> kvm@xxxxxxxxxxxxxxx (maintainer:KERNEL VIRTUAL MACHINE FOR RISC-V (KVM/riscv))
> kvm-riscv@xxxxxxxxxxxxxxxxxxx (maintainer:KERNEL VIRTUAL MACHINE FOR RISC-V (KVM/riscv))
> linux-riscv@xxxxxxxxxxxxxxxxxxx (maintainer:KERNEL VIRTUAL MACHINE FOR RISC-V (KVM/riscv))
>
> to find out who owns a tree.

I'm not sure this is useful.

It seems far simpler to grep the MAINTAINERS file for the repository.

And:

$ git grep "^T:" MAINTAINERS | sort | uniq -c | sort -rn | head -10
153 MAINTAINERS:T: git git://linuxtv.org/media_tree.git
70 MAINTAINERS:T: git git://anongit.freedesktop.org/drm/drm-misc
33 MAINTAINERS:T: git git://linuxtv.org/anttip/media_tree.git
9 MAINTAINERS:T: git git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound.git
6 MAINTAINERS:T: git git://linuxtv.org/mkrufky/tuners.git
6 MAINTAINERS:T: git git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux.git for-next/hardening
6 MAINTAINERS:T: git git://github.com/broadcom/stblinux.git
5 MAINTAINERS:T: git git://git.kernel.org/pub/scm/virt/kvm/kvm.git
5 MAINTAINERS:T: git git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm
5 MAINTAINERS:T: git git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu.git dev

I think I would not like to see the output for git repositories
with 153 matches. (or even 5 matches)

For instance: (I've more comments below this too)

$ ./scripts/get_maintainer.pl --for-tree=git://linuxtv.org/media_tree.git
Hans Verkuil <hverkuil@xxxxxxxxx> (maintainer:AIMSLAB FM RADIO RECEIVER DRIVER)
linux-media@xxxxxxxxxxxxxxx (maintainer:AIMSLAB FM RADIO RECEIVER DRIVER)
Maxime Ripard <mripard@xxxxxxxxxx> (maintainer:ALLWINNER A10 CSI DRIVER)
Paul Kocialkowski <paul.kocialkowski@xxxxxxxxxxx> (maintainer:ALLWINNER A31 MIPI CSI-2 BRIDGE DRIVER)
Tianshu Qiu <tian.shu.qiu@xxxxxxxxx> (maintainer:ASAHI KASEI AK7375 LENS VOICE COIL DRIVER)
Mauro Carvalho Chehab <mchehab@xxxxxxxxxx> (maintainer:AZ6007 DVB DRIVER)
Fabien Dessenne <fabien.dessenne@xxxxxxxxxxx> (supporter:BDISP ST MEDIA DRIVER)
Joe Tessler <jrt@xxxxxxxxxx> (maintainer:CHRONTEL CH7322 CEC DRIVER)
Yong Deng <yong.deng@xxxxxxxxxxxx> (maintainer:CSI DRIVERS FOR ALLWINNER V3s)
Andy Walls <awalls@xxxxxxxxxxxxxxxx> (maintainer:CX18 VIDEO4LINUX DRIVER)
Jernej Skrabec <jernej.skrabec@xxxxxxxxx> (maintainer:DEINTERLACE DRIVERS FOR ALLWINNER H3)
Hugues Fruchet <hugues.fruchet@xxxxxxxxxxx> (supporter:DELTA ST MEDIA DRIVER)
Sakari Ailus <sakari.ailus@xxxxxxxxxxxxxxx> (maintainer:DONGWOON DW9714 LENS VOICE COIL DRIVER)
Dongchun Zhu <dongchun.zhu@xxxxxxxxxxxx> (maintainer:DONGWOON DW9768 LENS VOICE COIL DRIVER)
Alexey Klimov <klimov.linux@xxxxxxxxx> (maintainer:DSBR100 USB FM RADIO DRIVER)
Michael Krufky <mkrufky@xxxxxxxxxxx> (maintainer:DVB_USB_CXUSB MEDIA DRIVER)
Charles-Antoine Couret <charles-antoine.couret@xxxxxxxxxxxx> (maintainer:GS1662 VIDEO SERIALIZER)
Frank Zago <frank@xxxxxxxx> (maintainer:GSPCA FINEPIX SUBDRIVER)
Olivier Lorin <o.lorin@xxxxxxxxxxx> (maintainer:GSPCA GL860 SUBDRIVER)
Erik Andren <erik.andren@xxxxxxxxx> (maintainer:GSPCA M5602 SUBDRIVER)
Brian Johnson <brijohn@xxxxxxxxx> (maintainer:GSPCA SN9C20X SUBDRIVER)
Leandro Costantino <lcostantino@xxxxxxxxx> (maintainer:GSPCA T613 SUBDRIVER)
Jean-Christophe Trotin <jean-christophe.trotin@xxxxxxxxxxx> (supporter:HVA ST MEDIA DRIVER)
Shawn Tu <shawnx.tu@xxxxxxxxx> (maintainer:HYNIX HI556 SENSOR DRIVER)
Yong Zhi <yong.zhi@xxxxxxxxx> (maintainer:INTEL IPU3 CSI-2 CIO2 DRIVER)
Bingbu Cao <bingbu.cao@xxxxxxxxx> (maintainer:INTEL IPU3 CSI-2 CIO2 DRIVER)
Dan Scally <djrscally@xxxxxxxxx> (maintainer:INTEL IPU3 CSI-2 CIO2 DRIVER)
Ramesh Shanmugasundaram <rashanmu@xxxxxxxxx> (maintainer:MAX2175 SDR TUNER DRIVER)
Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx> (supporter:MEDIA CONTROLLER FRAMEWORK)
Philipp Zabel <p.zabel@xxxxxxxxxxxxxx> (maintainer:MEDIA DRIVER FOR FREESCALE IMX PXP)
Sergey Kozlov <serjk@xxxxxxxx> (supporter:MEDIA DRIVERS FOR ASCOT2E)
Abylay Ospan <aospan@xxxxxxxx> (supporter:MEDIA DRIVERS FOR ASCOT2E)
Jasmin Jessich <jasmin@xxxxxx> (maintainer:MEDIA DRIVERS FOR CXD2099AR CI CONTROLLERS)
Yasunari Takiguchi <Yasunari.Takiguchi@xxxxxxxx> (supporter:MEDIA DRIVERS FOR CXD2880)
Steve Longerbeam <slongerbeam@xxxxxxxxx> (maintainer:MEDIA DRIVERS FOR FREESCALE IMX)
Rui Miguel Silva <rmfrfs@xxxxxxxxx> (maintainer:MEDIA DRIVERS FOR FREESCALE IMX7)
Dmitry Osipenko <digetx@xxxxxxxxx> (maintainer:MEDIA DRIVERS FOR NVIDIA TEGRA - VDE)
linux-tegra@xxxxxxxxxxxxxxx (maintainer:MEDIA DRIVERS FOR NVIDIA TEGRA - VDE)
Jacopo Mondi <jacopo@xxxxxxxxxx> (supporter:MEDIA DRIVERS FOR RENESAS - CEU)
linux-renesas-soc@xxxxxxxxxxxxxxx (supporter:MEDIA DRIVERS FOR RENESAS - CEU)
Fabrizio Castro <fabrizio.castro.jz@xxxxxxxxxxx> (supporter:MEDIA DRIVERS FOR RENESAS - DRIF)
Kieran Bingham <kieran.bingham+renesas@xxxxxxxxxxxxxxxx> (supporter:MEDIA DRIVERS FOR RENESAS - FDP1)
"Niklas Söderlund" <niklas.soderlund@xxxxxxxxxxxx> (supporter:MEDIA DRIVERS FOR RENESAS - VIN)
Neil Armstrong <neil.armstrong@xxxxxxxxxx> (supporter:MESON AO CEC DRIVER FOR AMLOGIC SOCS)
linux-amlogic@xxxxxxxxxxxxxxxxxxx (supporter:MESON AO CEC DRIVER FOR AMLOGIC SOCS)
Jimmy Su <jimmy.su@xxxxxxxxx> (maintainer:OMNIVISION OV08D10 SENSOR DRIVER)
Arec Kao <arec.kao@xxxxxxxxx> (maintainer:OMNIVISION OV13B10 SENSOR DRIVER)
Shunqian Zheng <zhengsq@xxxxxxxxxxxxxx> (maintainer:OMNIVISION OV2685 SENSOR DRIVER)
Dave Stevenson <dave.stevenson@xxxxxxxxxxxxxxx> (maintainer:OMNIVISION OV5647 SENSOR DRIVER)
Chiranjeevi Rapolu <chiranjeevi.rapolu@xxxxxxxxx> (maintainer:OMNIVISION OV5670 SENSOR DRIVER)
Wenyou Yang <wenyou.yang@xxxxxxxxxxxxx> (maintainer:OMNIVISION OV7740 SENSOR DRIVER)
"Paul J. Murphy" <paul.j.murphy@xxxxxxxxx> (maintainer:OMNIVISION OV9282 SENSOR DRIVER)
Daniele Alessandrelli <daniele.alessandrelli@xxxxxxxxx> (maintainer:OMNIVISION OV9282 SENSOR DRIVER)
Mike Isely <isely@xxxxxxxxx> (maintainer:PVRUSB2 VIDEO4LINUX DRIVER)
pvrusb2@xxxxxxxxx (maintainer:PVRUSB2 VIDEO4LINUX DRIVER)
Stanimir Varbanov <stanimir.varbanov@xxxxxxxxxx> (maintainer:QUALCOMM VENUS VIDEO ACCELERATOR DRIVER)
linux-arm-msm@xxxxxxxxxxxxxxx (maintainer:QUALCOMM VENUS VIDEO ACCELERATOR DRIVER)
Sean Young <sean@xxxxxxxx> (maintainer:RC-CORE / LIRC FRAMEWORK)
Eduardo Valentin <edubezval@xxxxxxxxx> (odd fixer:SI4713 FM RADIO TRANSMITTER I2C DRIVER)
Ricardo Ribalda <ribalda@xxxxxxxxxx> (maintainer:SONY IMX214 SENSOR DRIVER)
Leon Luo <leonl@xxxxxxxxxxxxxxxxxx> (maintainer:SONY IMX274 SENSOR DRIVER)
Manivannan Sadhasivam <mani@xxxxxxxxxx> (maintainer:SONY IMX290 SENSOR DRIVER)
Benjamin Mugnier <benjamin.mugnier@xxxxxxxxxxx> (maintainer:ST MIPID02 CSI-2 TO PARALLEL BRIDGE DRIVER)
Sylvain Petinot <sylvain.petinot@xxxxxxxxxxx> (maintainer:ST MIPID02 CSI-2 TO PARALLEL BRIDGE DRIVER)
Ezequiel Garcia <ezequiel@xxxxxxxxxxxxxxxxxxxx> (maintainer:STK1160 USB VIDEO CAPTURE DRIVER)
Olli Salonen <olli.salonen@xxxxxx> (maintainer:TDA18250 MEDIA DRIVER)
Antoine Jacquet <royale@xxxxxxxxxx> (maintainer:USB ZR364XX DRIVER)
linux-usb@xxxxxxxxxxxxxxx (maintainer:USB ZR364XX DRIVER)
Shuah Khan <skhan@xxxxxxxxxxxxxxxxxxx> (maintainer:VIMC VIRTUAL MEDIA CONTROLLER DRIVER)
"Daniel W. S. Almeida" <dwlsalmeida@xxxxxxxxx> (maintainer:VIDTV VIRTUAL DIGITAL TV DRIVER)
Hyun Kwon <hyun.kwon@xxxxxxxxxx> (supporter:XILINX VIDEO IP CORES)

And I don't know how this is an improvement as the --for-tree argument
seems _very_ likely to be typoed.

> diff --git a/scripts/get_maintainer.pl b/scripts/get_maintainer.pl
[]
> @@ -23,6 +23,7 @@ use File::Spec::Functions;
>
> my $cur_path = fastgetcwd() . '/';
> my $lk_path = "./";
> +my $for_tree = undef;
> my $email = 1;
> my $email_usename = 1;
> my $email_maintainer = 1;
> @@ -239,6 +240,7 @@ if ($#ARGV > 0) {
>
> if (!GetOptions(
> 'email!' => \$email,
> + 'for-tree=s' => \$for_tree,
> 'git!' => \$email_git,
> 'git-all-signature-types!' => \$email_git_all_signature_types,
> 'git-blame!' => \$email_git_blame,
> @@ -300,7 +302,7 @@ if (defined $self_test) {
> exit 0;
> }
>
> -if (-t STDIN && !@ARGV) {
> +if (-t STDIN && !@ARGV && !$for_tree) {
> # We're talking to a terminal, but have no command line arguments.
> die "$P: missing patchfile or -f file - use --help if necessary\n";
> }
> @@ -527,7 +529,7 @@ sub read_mailmap {
>
> ## use the filenames on the command line or find the filenames in the patchfiles
>
> -if (!@ARGV) {
> +if (!@ARGV && !$for_tree) {
> push(@ARGV, "&STDIN");
> }
>
> @@ -951,6 +953,47 @@ sub get_maintainers {
> }
> }
>
> + if ($for_tree) {
> + my $tvi = find_first_section();
> + while ($tvi < @typevalue) {
> + my $start = find_starting_index($tvi);
> + my $end = find_ending_index($tvi);
> + $tvi = $end + 1;
> +
> + my $i;
> + my $tree_match = 0;
> + for ($i = $start; $i < $end; $i++) {
> + my $line = $typevalue[$i];
> + if ($line =~ m/^([A-Z]):(.*)/) {
> + my $type = $1;
> + my $value = $2;
> +
> + if ($type eq 'T') {
> + if ($for_tree eq $value || "git $for_tree" eq $value) {
> + $tree_match = 1
> + }
> + }
> + }
> + }
> +
> + if ($tree_match) {
> + for ($i = $start; $i < $end; $i++) {
> + my $line = $typevalue[$i];
> + if ($line =~ m/^([A-Z]):(.*)/) {
> + my $type = $1;
> + my $value = $2;
> +
> + if ($type eq 'M' || $type eq 'L') {

And what about reviewers? 'R' ?

> + my $role = get_maintainer_role($i);

Also this improperly marks mailing lists as "maintainer:<SECTION>"
rather than "mailing list:<SECTION>" as it uses the S: value for
the section rather than the actual role of the person.

> + push_email_address($value, $role)
> + }
> + }
> + }
> + }
> + }
> + }
> +
> +
> foreach my $email (@email_to, @list_to) {
> $email->[0] = deduplicate_email($email->[0]);
> }
> @@ -1074,6 +1117,7 @@ Output type options:
> --multiline => print 1 entry per line
>
> Other options:
> + --for-tree => Get maintainers for the given tree
> --pattern-depth => Number of pattern directory traversals (default: 0 (all))
> --keywords => scan patch for keywords (default: $keywords)
> --sections => print all of the subsystem sections with pattern matches