Refactored apply_if helper functions

This commit is contained in:
Bartek Kryza
2023-06-01 00:06:32 +02:00
parent ae44c2413b
commit 112f7cb806
5 changed files with 21 additions and 18 deletions

View File

@@ -499,7 +499,7 @@ template_parameter template_builder::process_template_expansion(
LOG_DBG("Processing template expansion argument: {}", arg_name);
util::apply_if_not_null(
util::if_not_null(
arg.getAsTemplate().getAsTemplateDecl(), [&arg_name](const auto *decl) {
arg_name = decl->getQualifiedNameAsString();
});

View File

@@ -495,7 +495,7 @@ void translation_unit_visitor::process_constraint_requirements(
llvm::dyn_cast<clang::concepts::ExprRequirement>(req);
if (simple_req != nullptr) {
util::apply_if_not_null(
util::if_not_null(
simple_req->getExpr(), [&concept_model](const auto *e) {
auto simple_expr = common::to_string(e);
@@ -507,7 +507,7 @@ void translation_unit_visitor::process_constraint_requirements(
}
}
else if (req->getKind() == clang::concepts::Requirement::RK_Type) {
util::apply_if_not_null(
util::if_not_null(
llvm::dyn_cast<clang::concepts::TypeRequirement>(req),
[&concept_model, cpt](const auto *t) {
auto type_name = common::to_string(
@@ -525,7 +525,7 @@ void translation_unit_visitor::process_constraint_requirements(
llvm::dyn_cast<clang::concepts::NestedRequirement>(req);
if (nested_req != nullptr) {
util::apply_if_not_null(
util::if_not_null(
nested_req->getConstraintExpr(), [](const auto *e) {
LOG_DBG("=== Processing nested requirement: {}",
common::to_string(e));
@@ -805,7 +805,7 @@ std::unique_ptr<class_> translation_unit_visitor::create_record_declaration(
#if LLVM_VERSION_MAJOR < 16
if (record_name == "(anonymous)") {
util::apply_if_not_null(rec->getTypedefNameForAnonDecl(),
util::if_not_null(rec->getTypedefNameForAnonDecl(),
[&record_name](const clang::TypedefNameDecl *name) {
record_name = name->getNameAsString();
});
@@ -985,9 +985,8 @@ bool translation_unit_visitor::process_template_parameters(
default_arg, template_type_parameter->isParameterPack());
if (template_type_parameter->getTypeConstraint() != nullptr) {
util::apply_if_not_null(
template_type_parameter->getTypeConstraint()
->getNamedConcept(),
util::if_not_null(template_type_parameter->getTypeConstraint()
->getNamedConcept(),
[this, &ct, &templated_element](
const clang::ConceptDecl *named_concept) mutable {
ct.set_concept_constraint(