From mboxrd@z Thu Jan 1 00:00:00 1970 From: Thomas Monjalon Subject: [PATCH 3/3] scripts: check headline of drivers commits Date: Wed, 6 Jul 2016 12:38:50 +0200 Message-ID: <1467801530-20800-4-git-send-email-thomas.monjalon@6wind.com> References: <1467801530-20800-1-git-send-email-thomas.monjalon@6wind.com> Cc: Nelio Laranjeiro To: dev@dpdk.org Return-path: Received: from mail-wm0-f47.google.com (mail-wm0-f47.google.com [74.125.82.47]) by dpdk.org (Postfix) with ESMTP id DDEFB6CB1 for ; Wed, 6 Jul 2016 12:39:03 +0200 (CEST) Received: by mail-wm0-f47.google.com with SMTP id 187so31674128wmz.1 for ; Wed, 06 Jul 2016 03:39:03 -0700 (PDT) In-Reply-To: <1467801530-20800-1-git-send-email-thomas.monjalon@6wind.com> List-Id: patches and discussions about DPDK List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Nelio Laranjeiro A driver patch under net should start with "net/" or if a patch touch multiple drivers, it should only start with "net:". The same apply for crypto. A patch touching all drivers (net + crypto) should start with "drivers:". Longer prefixes like "net/mlx:" (for mlx4/mlx5) or "net/e1000/base:" are handled by not checking the colon. Signed-off-by: Nelio Laranjeiro Signed-off-by: Thomas Monjalon --- scripts/check-git-log.sh | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/scripts/check-git-log.sh b/scripts/check-git-log.sh index 833aa39..3f3cf19 100755 --- a/scripts/check-git-log.sh +++ b/scripts/check-git-log.sh @@ -70,6 +70,23 @@ bad=$(echo "$headlines" | grep --color=always \ | sed 's,^,\t,') [ -z "$bad" ] || printf "Wrong headline format:\n$bad\n" +# check headline prefix when touching only drivers/, e.g. net/ +bad=$(for commit in $commits ; do + headline=$(git log --format='%s' -1 $commit) + files=$(git diff-tree --no-commit-id --name-only -r $commit) + [ -z "$(echo "$files" | grep -v '^drivers/')" ] || continue + driversgrp=$(echo "$files" | cut -d "/" -f 2 | sort -u) + drivers=$(echo "$files" | cut -d "/" -f 2,3 | sort -u) + if [ $(echo "$driversgrp" | wc -l) -gt 1 ] ; then + bad=$(echo "$headline" | grep -v '^drivers:') + elif [ $(echo "$drivers" | wc -l) -gt 1 ] ; then + bad=$(echo "$headline" | grep -v "^$driversgrp") + else + bad=$(echo "$headline" | grep -v "^$drivers") + fi +done | sed 's,^,\t,') +[ -z "$bad" ] || printf "Wrong headline prefix:\n$bad\n" + # check headline label for common typos bad=$(echo "$headlines" | grep --color=always \ -e '^example[:/]' \ -- 2.7.0