mirror of
https://github.com/intel/llvm.git
synced 2026-02-02 10:08:59 +08:00
[C++20] [Modules] Handle reachability for partial specialization
Previously we don't catch the reachability for partial specialization. Handle them in this patch.
This commit is contained in:
@@ -4573,7 +4573,7 @@ Sema::CheckVarTemplateId(VarTemplateDecl *Template, SourceLocation TemplateLoc,
|
||||
void *InsertPos = nullptr;
|
||||
if (VarTemplateSpecializationDecl *Spec = Template->findSpecialization(
|
||||
Converted, InsertPos)) {
|
||||
checkSpecializationVisibility(TemplateNameLoc, Spec);
|
||||
checkSpecializationReachability(TemplateNameLoc, Spec);
|
||||
// If we already have a variable template specialization, return it.
|
||||
return Spec;
|
||||
}
|
||||
@@ -4694,7 +4694,7 @@ Sema::CheckVarTemplateId(VarTemplateDecl *Template, SourceLocation TemplateLoc,
|
||||
dyn_cast<VarTemplatePartialSpecializationDecl>(InstantiationPattern))
|
||||
Decl->setInstantiationOf(D, InstantiationArgs);
|
||||
|
||||
checkSpecializationVisibility(TemplateNameLoc, Decl);
|
||||
checkSpecializationReachability(TemplateNameLoc, Decl);
|
||||
|
||||
assert(Decl && "No variable template specialization?");
|
||||
return Decl;
|
||||
|
||||
34
clang/test/Modules/partial_specialization.cppm
Normal file
34
clang/test/Modules/partial_specialization.cppm
Normal file
@@ -0,0 +1,34 @@
|
||||
// RUN: rm -rf %t
|
||||
// RUN: split-file %s %t
|
||||
// RUN: cd %t
|
||||
//
|
||||
// RUN: %clang_cc1 -std=c++20 -emit-module-interface %t/A.cppm -o %t/A.pcm
|
||||
// RUN: %clang_cc1 -std=c++20 -fprebuilt-module-path=%t %t/Use.cpp -fsyntax-only -verify
|
||||
//
|
||||
//--- foo.h
|
||||
template<typename T, typename U>
|
||||
inline constexpr bool IsSame = false;
|
||||
|
||||
template<typename T>
|
||||
inline constexpr bool IsSame<T, T> = true;
|
||||
|
||||
template <typename T>
|
||||
class A {
|
||||
public:
|
||||
A();
|
||||
~A() noexcept(IsSame<T, T>);
|
||||
};
|
||||
|
||||
//--- A.cppm
|
||||
module;
|
||||
#include "foo.h"
|
||||
export module A;
|
||||
export using ::A;
|
||||
|
||||
//--- Use.cpp
|
||||
import A;
|
||||
void bool_consume(bool b);
|
||||
void use() {
|
||||
A<int> a{};
|
||||
bool_consume(IsSame); // expected-error {{use of undeclared identifier 'IsSame'}}
|
||||
}
|
||||
Reference in New Issue
Block a user