blob: 5267ac658b8be1a913a2e81d860aa375cc49fd8c [file] [log] [blame]
// RUN: rm -rf %t
// RUN: mkdir %t
// RUN: echo 'namespace N { enum E { A }; }' > %t/a.h
// RUN: echo '#include "a.h"' > %t/b.h
// RUN: touch %t/x.h
// RUN: echo 'module B { module b { header "b.h" } module x { header "x.h" } }' > %t/b.modulemap
// RUN: %clang_cc1 -fmodules -fmodules-cache-path=%t -x c++ -fmodule-map-file=%t/b.modulemap %s -I%t -verify -fmodules-local-submodule-visibility
// RUN: %clang_cc1 -fmodules -fmodules-cache-path=%t -x c++ -fmodule-map-file=%t/b.modulemap %s -I%t -verify -fmodules-local-submodule-visibility -DMERGE_LATE
#ifndef MERGE_LATE
// expected-no-diagnostics
#include "a.h"
#endif
#include "x.h"
#ifdef MERGE_LATE
namespace N {
// FIXME: Should we accept this and reject the usage below due to ambiguity instead?
enum { A } a; // expected-error {{redefinition of enumerator 'A'}}
// expected-note@a.h:1 {{here}} (from module B.b)
}
#include "a.h"
#endif
N::E e = N::A;