mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-16 02:26:37 +00:00

We've found that basic profiling could help improving/optimizing when developing clang-tidy checks. This PR adds an extra command ``` set enable-profile (true|false) Set whether to enable matcher profiling. ``` which enables profiling queries on each file. Sample output: ``` $ cat test.cql set enable-profile true m binaryOperator(isExpansionInMainFile()) $ cat test.c int test(int i, int j) { return i + j; } $ clang-query --track-memory -f test.cql test.c -- Match #1: {{.*}}/test.c:2:10: note: "root" binds here 2 | return i + j; | ^~~~~ 1 match. ===-------------------------------------------------------------------------=== clang-query matcher profiling ===-------------------------------------------------------------------------=== Total Execution Time: 0.0000 seconds (0.0000 wall clock) ---User Time--- --System Time-- --User+System-- ---Wall Time--- ---Mem--- --- Name --- 0.0000 (100.0%) 0.0000 (100.0%) 0.0000 (100.0%) 0.0000 (100.0%) 224 {{.*}}/test.c 0.0000 (100.0%) 0.0000 (100.0%) 0.0000 (100.0%) 0.0000 (100.0%) 224 Total ```
50 lines
1.3 KiB
C++
50 lines
1.3 KiB
C++
//===--- QuerySession.h - clang-query ---------------------------*- 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 LLVM_CLANG_TOOLS_EXTRA_CLANG_QUERY_QUERY_SESSION_H
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANG_QUERY_QUERY_SESSION_H
|
|
|
|
#include "clang/AST/ASTTypeTraits.h"
|
|
#include "clang/ASTMatchers/Dynamic/VariantValue.h"
|
|
#include "llvm/ADT/ArrayRef.h"
|
|
#include "llvm/ADT/StringMap.h"
|
|
|
|
namespace clang {
|
|
|
|
class ASTUnit;
|
|
|
|
namespace query {
|
|
|
|
/// Represents the state for a particular clang-query session.
|
|
class QuerySession {
|
|
public:
|
|
QuerySession(llvm::ArrayRef<std::unique_ptr<ASTUnit>> ASTs)
|
|
: ASTs(ASTs), PrintOutput(false), DiagOutput(true),
|
|
DetailedASTOutput(false), BindRoot(true), PrintMatcher(false),
|
|
EnableProfile(false), Terminate(false), TK(TK_AsIs) {}
|
|
|
|
llvm::ArrayRef<std::unique_ptr<ASTUnit>> ASTs;
|
|
|
|
bool PrintOutput;
|
|
bool DiagOutput;
|
|
bool DetailedASTOutput;
|
|
|
|
bool BindRoot;
|
|
bool PrintMatcher;
|
|
bool EnableProfile;
|
|
bool Terminate;
|
|
|
|
TraversalKind TK;
|
|
llvm::StringMap<ast_matchers::dynamic::VariantValue> NamedValues;
|
|
};
|
|
|
|
} // namespace query
|
|
} // namespace clang
|
|
|
|
#endif
|