llvm-project/clang/test/Modules/ctor.arg.dep.cppm
Chuanqi Xu 99daf6b263 [C++20] [Modules] Don't handle no linkage entities when overloading
The original implementation uses `ND->getFormalLinkage() <=
Linkage::InternalLinkage`. It is not right since the spec only says
internal linkage and it doesn't mention 'no linkage'. This matters when
we consider constructors. According to [class.ctor.general]p1,
constructors have no name so constructors have no linkage too.
2022-07-26 21:07:41 +08:00

45 lines
641 B
C++

// RUN: rm -rf %t
// RUN: split-file %s %t
// RUN: cd %t
//
// RUN: %clang_cc1 -std=c++20 %t/A.cppm -I%t -emit-module-interface -o %t/A.pcm
// RUN: %clang_cc1 -std=c++20 -fprebuilt-module-path=%t %t/Use.cpp -verify -fsyntax-only
//
//--- foo.h
namespace ns {
struct T {
T(void*);
};
struct A {
template <typename F>
A(F f) : t(&f) {}
T t;
};
template <typename T>
void foo(T) {
auto f = [](){};
ns::A a(f);
}
}
//--- A.cppm
module;
#include "foo.h"
export module A;
export namespace ns {
using ns::A;
using ns::foo;
}
//--- Use.cpp
// expected-no-diagnostics
import A;
void test() {
ns::foo(5);
}