blob: 6b84e6e70a507d791f7251e6d9075c4f68f6b6b4 [file] [log] [blame]
// RUN: %clang_cc1 -fsyntax-only -Wheader-hygiene -verify %s
#ifdef BE_THE_HEADER
namespace warn_in_header_in_global_context {}
using namespace warn_in_header_in_global_context; // expected-warning {{using namespace directive in global context in header}}
// 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; // expected-warning {{using namespace directive in global context in header}}
}
// This is really silly, but we should warn on it:
extern "C++" {
extern "C" {
extern "C++" {
using namespace warn_inside_linkage; // expected-warning {{using namespace directive in global context in header}}
}
}
}
// 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 // expected-warning {{using namespace directive in global context in header}}
#else
#define BE_THE_HEADER
#include __FILE__
namespace dont_warn {}
using namespace dont_warn;
// |using namespace| through a macro shouldn't warn if the instantiation is in a
// cc file.
USING_MACRO
// Check behavior of line markers.
namespace warn_header_with_line_marker {}
# 1 "XXX.h" 1
using namespace warn_header_with_line_marker; // expected-warning {{using namespace directive in global context in header}}
# 70 "warn-using-namespace-in-header.cpp" 2
namespace nowarn_after_line_marker {}
using namespace nowarn_after_line_marker;
#endif