forked from OSchip/llvm-project
[clang-tidy] Make google-objc-function-naming ignore implicit functions 🙈
Summary: Implicit functions are outside the control of source authors and should be exempt from style restrictions. Tested via running clang tools tests. This is an amended followup to https://reviews.llvm.org/D57207 Reviewers: aaron.ballman Reviewed By: aaron.ballman Subscribers: jdoerfert, xazax.hun, cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D58095 llvm-svn: 354534
This commit is contained in:
parent
9c9a8a96d3
commit
3eea706e3e
|
@ -93,12 +93,16 @@ void FunctionNamingCheck::registerMatchers(MatchFinder *Finder) {
|
||||||
if (!getLangOpts().ObjC)
|
if (!getLangOpts().ObjC)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Match function declarations that are not in system headers and are not
|
// Enforce Objective-C function naming conventions on all functions except:
|
||||||
// main.
|
// • Functions defined in system headers.
|
||||||
|
// • C++ member functions.
|
||||||
|
// • Namespaced functions.
|
||||||
|
// • Implicitly defined functions.
|
||||||
|
// • The main function.
|
||||||
Finder->addMatcher(
|
Finder->addMatcher(
|
||||||
functionDecl(
|
functionDecl(
|
||||||
unless(anyOf(isExpansionInSystemHeader(), cxxMethodDecl(),
|
unless(anyOf(isExpansionInSystemHeader(), cxxMethodDecl(),
|
||||||
hasAncestor(namespaceDecl()), isMain(),
|
hasAncestor(namespaceDecl()), isMain(), isImplicit(),
|
||||||
matchesName(validFunctionNameRegex(true)),
|
matchesName(validFunctionNameRegex(true)),
|
||||||
allOf(isStaticStorageClass(),
|
allOf(isStaticStorageClass(),
|
||||||
matchesName(validFunctionNameRegex(false))))))
|
matchesName(validFunctionNameRegex(false))))))
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
//===--- stdio.h - Stub header for tests ------------------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||||||
|
// See https://llvm.org/LICENSE.txt for license information.
|
||||||
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef _STDIO_H_
|
||||||
|
#define _STDIO_H_
|
||||||
|
|
||||||
|
// A header intended to contain C standard input and output library
|
||||||
|
// declarations.
|
||||||
|
|
||||||
|
int printf(const char *, ...);
|
||||||
|
|
||||||
|
#endif // _STDIO_H_
|
||||||
|
|
|
@ -1,4 +1,12 @@
|
||||||
// RUN: %check_clang_tidy %s google-objc-function-naming %t
|
// RUN: %check_clang_tidy %s google-objc-function-naming %t -- -- -isystem %S/Inputs/Headers
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
static void TestImplicitFunctionDeclaration(int a) {
|
||||||
|
// Call a builtin function so that the compiler generates an implicit
|
||||||
|
// function declaration.
|
||||||
|
printf("%d", a);
|
||||||
|
}
|
||||||
|
|
||||||
typedef _Bool bool;
|
typedef _Bool bool;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue