aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/clang_tidy/arcadia_checks/usage_restriction_checks.cpp
diff options
context:
space:
mode:
authorvitalyisaev <vitalyisaev@yandex-team.com>2023-06-29 10:00:50 +0300
committervitalyisaev <vitalyisaev@yandex-team.com>2023-06-29 10:00:50 +0300
commit6ffe9e53658409f212834330e13564e4952558f6 (patch)
tree85b1e00183517648b228aafa7c8fb07f5276f419 /library/cpp/clang_tidy/arcadia_checks/usage_restriction_checks.cpp
parent726057070f9c5a91fc10fde0d5024913d10f1ab9 (diff)
downloadydb-6ffe9e53658409f212834330e13564e4952558f6.tar.gz
YQ Connector: support managed ClickHouse
Со стороны dqrun можно обратиться к инстансу коннектора, который работает на streaming стенде, и извлечь данные из облачного CH.
Diffstat (limited to 'library/cpp/clang_tidy/arcadia_checks/usage_restriction_checks.cpp')
-rw-r--r--library/cpp/clang_tidy/arcadia_checks/usage_restriction_checks.cpp24
1 files changed, 24 insertions, 0 deletions
diff --git a/library/cpp/clang_tidy/arcadia_checks/usage_restriction_checks.cpp b/library/cpp/clang_tidy/arcadia_checks/usage_restriction_checks.cpp
new file mode 100644
index 0000000000..bc825fa18f
--- /dev/null
+++ b/library/cpp/clang_tidy/arcadia_checks/usage_restriction_checks.cpp
@@ -0,0 +1,24 @@
+#include "usage_restriction_checks.h"
+#include <contrib/libs/clang16/include/clang/AST/ASTContext.h>
+#include <contrib/libs/clang16/include/clang/ASTMatchers/ASTMatchFinder.h>
+
+using namespace clang::ast_matchers;
+
+namespace clang::tidy::arcadia {
+ void TypeidNameRestrictionCheck::registerMatchers(MatchFinder* Finder) {
+ Finder->addMatcher(cxxMemberCallExpr(on(expr(hasType(namedDecl(hasName("::std::type_info")))).bind("expr")),
+ callee(cxxMethodDecl(allOf(hasName("name"), parameterCountIs(0))))),
+ this);
+ Finder->addMatcher(cxxMemberCallExpr(on(expr(hasType(namedDecl(hasName("::std::type_index")))).bind("expr")),
+ callee(cxxMethodDecl(allOf(hasName("name"), parameterCountIs(0))))),
+ this);
+ }
+
+ void TypeidNameRestrictionCheck::check(const MatchFinder::MatchResult& Result) {
+ const auto node = Result.Nodes.getNodeAs<Expr>("expr");
+
+ diag(node->getBeginLoc(), "Both std::type_info::name() and std::type_index::name() return mangled typename. "
+ "Consider using TypeName() functions from <util/system/type_name.h> instead");
+ }
+
+}