YouCompleteMe/cpp/llvm/tools/clang/test/Modules/namespaces.cpp
Strahinja Val Markovic 1f51a89d39 Adding more llvm/clang files
These were ignored by git accidentally. We want ALL OF THEM since they all came
in the llvm/clang source distribution.
2012-07-05 17:55:45 -07:00

65 lines
1.7 KiB
C++

// RUN: rm -rf %t
// RUN: %clang_cc1 -x objective-c++ -fmodules -fmodule-cache-path %t -I %S/Inputs %s -verify
// Importing modules which add declarations to a pre-existing non-imported
// overload set does not currently work.
// XFAIL: *
namespace N6 {
char &f(char);
}
namespace N8 { }
@__experimental_modules_import namespaces_left;
@__experimental_modules_import namespaces_right;
void test() {
int &ir1 = N1::f(1);
int &ir2 = N2::f(1);
int &ir3 = N3::f(1);
float &fr1 = N1::f(1.0f);
float &fr2 = N2::f(1.0f);
double &dr1 = N2::f(1.0);
double &dr2 = N3::f(1.0);
}
// Test namespaces merged without a common first declaration.
namespace N5 {
char &f(char);
}
namespace N10 {
int &f(int);
}
void testMerged() {
int &ir1 = N5::f(17);
int &ir2 = N6::f(17);
int &ir3 = N7::f(17);
double &fr1 = N5::f(1.0);
double &fr2 = N6::f(1.0);
double &fr3 = N7::f(1.0);
char &cr1 = N5::f('a');
char &cr2 = N6::f('b');
}
// Test merging of declarations within namespaces that themselves were
// merged without a common first declaration.
void testMergedMerged() {
int &ir1 = N8::f(17);
int &ir2 = N9::f(17);
int &ir3 = N10::f(17);
}
// Test merging when using anonymous namespaces, which does not
// actually perform any merging.
// other file: expected-note{{passing argument to parameter here}}
void testAnonymousNotMerged() {
N11::consumeFoo(N11::getFoo()); // expected-error{{cannot initialize a parameter of type 'N11::<anonymous>::Foo *' with an rvalue of type 'N11::<anonymous>::Foo *'}}
N12::consumeFoo(N12::getFoo()); // expected-error{{cannot initialize a parameter of type 'N12::<anonymous>::Foo *' with an rvalue of type 'N12::<anonymous>::Foo *'}}
}
// other file: expected-note{{passing argument to parameter here}}