summaryrefslogtreecommitdiff
path: root/clang/test/SemaCXX/warn-using-namespace-in-header.h
blob: b544c548ae9bb11d205b753695ac4ba9828f1313 (about) (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50





// Lots of vertical space to make the error line match up with the line of the
// expected line in the source file.
namespace warn_in_header_in_global_context {}
using namespace warn_in_header_in_global_context;

// While we want to error on the previous using directive, we don't when we are
// inside a namespace
namespace dont_warn_here {
using namespace warn_in_header_in_global_context;
}

// We should warn in toplevel extern contexts.
namespace warn_inside_linkage {}
extern "C++" {
using namespace warn_inside_linkage;
}

// This is really silly, but we should warn on it:
extern "C++" {
extern "C" {
extern "C++" {
using namespace warn_inside_linkage;
}
}
}

// But we shouldn't warn in extern contexts inside namespaces.
namespace dont_warn_here {
extern "C++" {
using namespace warn_in_header_in_global_context;
}
}

// We also shouldn't warn in case of functions.
inline void foo() {
  using namespace warn_in_header_in_global_context;
}


namespace macronamespace {}
#define USING_MACRO using namespace macronamespace;

// |using namespace| through a macro should warn if the instantiation is in a
// header.
USING_MACRO