From: Daniel Jasper Date: Fri, 13 Mar 2015 14:29:39 +0000 (+0000) Subject: When building a module, all headers of submodules can be used. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=65c0c8ae7372a5b064317f0ec2ea69fae03e5444;p=clang When building a module, all headers of submodules can be used. This extends r232159. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@232168 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Lex/ModuleMap.cpp b/lib/Lex/ModuleMap.cpp index 6aefb03526..b0195af70b 100644 --- a/lib/Lex/ModuleMap.cpp +++ b/lib/Lex/ModuleMap.cpp @@ -265,7 +265,8 @@ void ModuleMap::diagnoseHeaderInclusion(Module *RequestingModule, if (Known != Headers.end()) { for (const KnownHeader &Header : Known->second) { // If 'File' is part of 'RequestingModule' we can definitely include it. - if (Header.getModule() == RequestingModule) + if (Header.getModule() && + Header.getModule()->isSubModuleOf(RequestingModule)) return; // Remember private headers for later printing of a diagnostic. diff --git a/test/Modules/declare-use5.cpp b/test/Modules/declare-use5.cpp new file mode 100644 index 0000000000..b34be0f110 --- /dev/null +++ b/test/Modules/declare-use5.cpp @@ -0,0 +1,9 @@ +// RUN: rm -rf %t +// RUN: %clang_cc1 -fmodule-maps -fmodules-cache-path=%t -fmodules-decluse -fmodule-name=XN -I %S/Inputs/declare-use %s -verify + + +#include "sub.h" + +const int a = sub; + +// expected-no-diagnostics