[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:
Stephane Moore 2019-02-21 00:34:01 +00:00
parent 9c9a8a96d3
commit 3eea706e3e
3 changed files with 34 additions and 4 deletions

View File

@ -93,12 +93,16 @@ void FunctionNamingCheck::registerMatchers(MatchFinder *Finder) {
if (!getLangOpts().ObjC)
return;
// Match function declarations that are not in system headers and are not
// main.
// Enforce Objective-C function naming conventions on all functions except:
// • Functions defined in system headers.
// • C++ member functions.
// • Namespaced functions.
// • Implicitly defined functions.
// • The main function.
Finder->addMatcher(
functionDecl(
unless(anyOf(isExpansionInSystemHeader(), cxxMethodDecl(),
hasAncestor(namespaceDecl()), isMain(),
hasAncestor(namespaceDecl()), isMain(), isImplicit(),
matchesName(validFunctionNameRegex(true)),
allOf(isStaticStorageClass(),
matchesName(validFunctionNameRegex(false))))))

View File

@ -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_

View File

@ -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;