Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2885247pxv; Sun, 27 Jun 2021 11:54:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwDJqbUYWq9AZ2LzzXYYsq1sPNcDzYIXDFhtuusHOeAIS4Ck3hxl/DkV017b2D5p0BP4SuP X-Received: by 2002:a05:6638:380b:: with SMTP id i11mr19092871jav.57.1624820081767; Sun, 27 Jun 2021 11:54:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1624820081; cv=none; d=google.com; s=arc-20160816; b=m6ZiYKfxBW2/ngGxUnEmQwmbxhYZmsjvDmnMPum352og6ah4yN7H+xB0CPTNPPBxkY TLhyTjIh0Fz8ucQSyG8v7dSrsvKoKEZpAD016pANN7uymMuUDYD/YKGoCowzFi072xjj Nz5WRjR7V03KGnyGZI6kHGgv4rowhcX63p2FYDHQrmWWM/4KxCv18if8ESTL3/L7MqPz M+shh2AekSyRYZLg7pga2C1pzHDMFo6GlL6RBYreigWyv+f5VYvXtL4qaBwNOtQJarvP u+W5THZQ+n23nSdXACWpCj4BaqeCdRUxWM6ecfqbAmm6WrDB4UwnDhKsLVlvJDgRuD/B kB4Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=8/B0ymtcimNR7SfdkvPNRS/tYCD0gKLRQgRQfe/XPmk=; b=z8USsvmHymq20VGCkievxhrxFc+Ll9h1nK55V0LUyaJ+enoPkOUXMUBVbdOyBfjbXk mDLLQm5/cNjAW+KvQvm49pYr7Ih57gtVZ+jl2fKOvv80tkte3Qxurnny8257PCTN0/Gv TmxgNMnVKRNibd60F3uRciDDg2SFrnM/a1B/F5XFmbf35HeZxlRHf9S/hRrvV76gBqms lz5FM9o9ScGCU0xL+wD+YWbA2OnmzbQ4Chx8YF7lwOEU1vh638MYr2vFEC67CBm5o8Vg rMVnIdYBbpkxid/Tt4Y3j6A0d48NleB5mbWYWA2ZG9FtlBjQv3YC9N7YAIu2yHVQxmEb Y78A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=P4EoSzRy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a13si13094572ilj.80.2021.06.27.11.54.06; Sun, 27 Jun 2021 11:54:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=P4EoSzRy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231335AbhF0Svo (ORCPT + 99 others); Sun, 27 Jun 2021 14:51:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59546 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231288AbhF0Svo (ORCPT ); Sun, 27 Jun 2021 14:51:44 -0400 Received: from mail-pj1-x1034.google.com (mail-pj1-x1034.google.com [IPv6:2607:f8b0:4864:20::1034]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D6455C061574 for ; Sun, 27 Jun 2021 11:49:19 -0700 (PDT) Received: by mail-pj1-x1034.google.com with SMTP id p4-20020a17090a9304b029016f3020d867so8880331pjo.3 for ; Sun, 27 Jun 2021 11:49:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=8/B0ymtcimNR7SfdkvPNRS/tYCD0gKLRQgRQfe/XPmk=; b=P4EoSzRyJEioZVe1Gpfb78yHN60fDhkEfSk4YGJuRb6pPt4idQQyrEGqyqmeMLPOEf pcWKNWkvtCaghG4Yx/dP12nURmjvezzN5wHlg8Zyxuy/jeFJg/BPVEGP/C2r7NeTBubk 22Xx5UaS/nlhfXVPPSAD4Lu8lf2G9XtnrQ/8miJnyQ0Qr+zkeNqJWP3GgvEMuqvUJ6ZX HcFXp1/g6NLnr3eijk3ecOyF3dw8epjud+PyStYfQdnxi3YyMYcafS6ngaEFpuPdOjgX weT054BLfmzxL1AGn0y3JfpwS32l0WwWNkENDoVWuDfICrDWcplaIoOCjJ5QHOdMxU6z mUQQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=8/B0ymtcimNR7SfdkvPNRS/tYCD0gKLRQgRQfe/XPmk=; b=FmAp4xWUXWV3OKwE4I/NX2Qa8sdbX092nK9KagTAW5htyGSd8wYIegFRrTd0mGdRWT g9mRQWiLYYC4dLaMKBn8fE5CTAbrWeMgB9us0S7L7gZhvASdx0xNlQCE+8KnLM6RTN+r Eub9/JnNiYHyIfDrEgGimUZ1DOVbGSvb6nAEMNcixep4kNBDM5q/uRmjHo+QtXEaXvep pq+VosHdw1chDxIKWljAJazbP9+NhkdKdZBmXQU1B8Jq0A96uk3+/UvFHO+TXrOTGMKw rA0Xa+t0fuRkRDuFWtHP41455jK9ywcBIgdZXkCpWqtqFqWEGgZ+6DeMIVU+J4q4gMHC 92yA== X-Gm-Message-State: AOAM531ZuInC0kq5wR6n6fQT2r0so8J6PxswUklmm2y3DxLACkNbxoCw fruQNsd07GsYc1qX2u2+rws= X-Received: by 2002:a17:90a:fa8c:: with SMTP id cu12mr8438049pjb.171.1624819759142; Sun, 27 Jun 2021 11:49:19 -0700 (PDT) Received: from localhost.localdomain ([49.37.3.74]) by smtp.gmail.com with ESMTPSA id y7sm12114478pfy.153.2021.06.27.11.49.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 27 Jun 2021 11:49:18 -0700 (PDT) From: Dwaipayan Ray To: joe@perches.com, apw@canonical.com Cc: lukas.bulwahn@gmail.com, linux-kernel@vger.kernel.org, Dwaipayan Ray , Alejandro Colomar Subject: [PATCH v2] checkpatch: Fix regex for do without braces Date: Mon, 28 Jun 2021 00:19:09 +0530 Message-Id: <20210627184909.6000-1-dwaipayanray1@gmail.com> X-Mailer: git-send-email 2.28.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The regular expression for detecting do without braces also passes when checkpatch encounters the "double" keyword. This causes wrong recalculation of $stat in checkpatch which can cause false positives. Fix the regex to avoid the above. Also update the comments for the check. Reported-by: Alejandro Colomar Signed-off-by: Dwaipayan Ray --- Changes in v2: - Check word boundary on both sides of do scripts/checkpatch.pl | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl index 8d19beca3538..64036e7eff71 100755 --- a/scripts/checkpatch.pl +++ b/scripts/checkpatch.pl @@ -5488,9 +5488,8 @@ sub process { } } -# Check for illegal assignment in if conditional -- and check for trailing -# statements after the conditional. - if ($line =~ /do\s*(?!{)/) { +# If we have sufficient context detect and handle do without braces ({). + if ($line =~ /\bdo\b\s*(?!{)/) { ($stat, $cond, $line_nr_next, $remain_next, $off_next) = ctx_statement_block($linenr, $realcnt, 0) if (!defined $stat); @@ -5511,6 +5510,9 @@ sub process { $offset} = 1; } } + +# Check for illegal assignment in if conditional -- and check for trailing +# statements after the conditional. if (!defined $suppress_whiletrailers{$linenr} && defined($stat) && defined($cond) && $line =~ /\b(?:if|while|for)\s*\(/ && $line !~ /^.\s*#/) { -- 2.28.0