teak-llvm/clang/test/SemaCXX/warn-using-namespace-in-header.cpp
Eli Friedman 5ba37d5282 Split isFromMainFile into two functions.
Basically, isInMainFile considers line markers, and isWrittenInMainFile
doesn't.  Distinguishing between the two is useful when dealing with
files which are preprocessed files or rewritten with -frewrite-includes
(so we don't, for example, print useless warnings).

llvm-svn: 188968
2013-08-22 00:27:10 +00:00

70 lines
1.9 KiB
C++

// 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