Skip to content

Commit

Permalink
[modules] Don't load files specified by -fmodule-file= when modules are
Browse files Browse the repository at this point in the history
disabled. (We still allow this via -cc1 / -Xclang, primarily for testing.)


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@247384 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
zygoloid committed Sep 11, 2015
1 parent c0de2d0 commit e8c9862
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 1 deletion.
5 changes: 4 additions & 1 deletion lib/Driver/Tools.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4461,7 +4461,10 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
Args.AddAllArgs(CmdArgs, options::OPT_fmodule_map_file);

// -fmodule-file can be used to specify files containing precompiled modules.
Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
if (HaveModules)
Args.AddAllArgs(CmdArgs, options::OPT_fmodule_file);
else
Args.ClaimAllArgs(options::OPT_fmodule_file);

// -fmodule-cache-path specifies where our implicitly-built module files
// should be written.
Expand Down
10 changes: 10 additions & 0 deletions test/Driver/modules.m
Original file line number Diff line number Diff line change
Expand Up @@ -37,3 +37,13 @@
// CHECK-MODULE-MAP-FILES: "-fmodules"
// CHECK-MODULE-MAP-FILES: "-fmodule-map-file=foo.map"
// CHECK-MODULE-MAP-FILES: "-fmodule-map-file=bar.map"

// RUN: %clang -fmodules -fmodule-file=foo.pcm -fmodule-file=bar.pcm -### %s 2>&1 | FileCheck -check-prefix=CHECK-MODULE-FILES %s
// CHECK-MODULE-FILES: "-fmodules"
// CHECK-MODULE-FILES: "-fmodule-file=foo.pcm"
// CHECK-MODULE-FILES: "-fmodule-file=bar.pcm"

// RUN: %clang -fno-modules -fmodule-file=foo.pcm -fmodule-file=bar.pcm -### %s 2>&1 | FileCheck -check-prefix=CHECK-NO-MODULE-FILES %s
// CHECK-NO-MODULE-FILES-NOT: "-fmodules"
// CHECK-NO-MODULE-FILES-NOT: "-fmodule-file=foo.pcm"
// CHECK-NO-MODULE-FILES-NOT: "-fmodule-file=bar.pcm"

0 comments on commit e8c9862

Please sign in to comment.