summaryrefslogtreecommitdiffstats
path: root/clang/test/Modules/Inputs
diff options
context:
space:
mode:
authorDuncan P. N. Exon Smith <dexonsmith@apple.com>2017-04-15 00:07:57 +0000
committerDuncan P. N. Exon Smith <dexonsmith@apple.com>2017-04-15 00:07:57 +0000
commit03df14c6dd2ae36b04d0a085ae9fa69aad8193ab (patch)
treed940bdde9086e4bb1732b2f3774825d870b2697a /clang/test/Modules/Inputs
parent044f956f9af8b8f4c8a2ccf5dde5cd48d34a5721 (diff)
downloadbcm5719-llvm-03df14c6dd2ae36b04d0a085ae9fa69aad8193ab.tar.gz
bcm5719-llvm-03df14c6dd2ae36b04d0a085ae9fa69aad8193ab.zip
Modules: Do not serialize #pragma pack state
The modules side of r299226, which serializes #pragma pack state, doesn't work well. The main purpose was to make -include and -include-pch match semantics (the PCH side). We also started serializing #pragma pack in PCMs, in the hopes of making modules and non-modules builds more consistent. But consider: $ cat a.h $ cat b.h #pragma pack(push, 2) $ cat module.modulemap module M { module a { header "a.h" } module b { header "b.h" } } $ cat t.cpp #include "a.h" #pragma pack(show) As of r299226, the #pragma pack(show) gives "2", even though we've only included "a.h". - With -fmodules-local-submodule-visibility, this is clearly wrong. We should get the default state (8 on x86_64). - Without -fmodules-local-submodule-visibility, this kind of matches how other things work (as if include-the-whole-module), but it's still really terrible, and it doesn't actually make modules and non-modules builds more consistent. This commit disables the serialization for modules, essentially a partial revert of r299226. Going forward: 1. Having this #pragma pack stuff escape is terrible design (or, more often, a horrible bug). We should prioritize adding warnings (maybe -Werror by default?). 2. If we eventually reintroduce this for modules, it should only apply to -fmodules-local-submodule-visibility, and it should be tracked on a per-submodule basis. llvm-svn: 300380
Diffstat (limited to 'clang/test/Modules/Inputs')
-rw-r--r--clang/test/Modules/Inputs/module.map17
-rw-r--r--clang/test/Modules/Inputs/pragma_pack_push.h6
-rw-r--r--clang/test/Modules/Inputs/pragma_pack_reset_push.h4
3 files changed, 3 insertions, 24 deletions
diff --git a/clang/test/Modules/Inputs/module.map b/clang/test/Modules/Inputs/module.map
index dcb60bea851..b95eec351e8 100644
--- a/clang/test/Modules/Inputs/module.map
+++ b/clang/test/Modules/Inputs/module.map
@@ -265,20 +265,9 @@ module diag_pragma {
header "diag_pragma.h"
}
-module pragma_pack_set {
- header "pragma_pack_set.h"
-}
-
-module pragma_pack_push {
- header "pragma_pack_push.h"
-}
-
-module pragma_pack_empty {
- header "empty.h"
-}
-
-module pragma_pack_reset_push {
- header "pragma_pack_reset_push.h"
+module pragma_pack {
+ module set { header "pragma_pack_set.h" }
+ module empty { header "empty.h" }
}
module dummy {
diff --git a/clang/test/Modules/Inputs/pragma_pack_push.h b/clang/test/Modules/Inputs/pragma_pack_push.h
deleted file mode 100644
index 4fc66e51cf8..00000000000
--- a/clang/test/Modules/Inputs/pragma_pack_push.h
+++ /dev/null
@@ -1,6 +0,0 @@
-
-#pragma pack (push, 4)
-#pragma pack (push, 2)
-#pragma pack (push, 1)
-#pragma pack (pop)
-
diff --git a/clang/test/Modules/Inputs/pragma_pack_reset_push.h b/clang/test/Modules/Inputs/pragma_pack_reset_push.h
deleted file mode 100644
index 18f50a00952..00000000000
--- a/clang/test/Modules/Inputs/pragma_pack_reset_push.h
+++ /dev/null
@@ -1,4 +0,0 @@
-
-#pragma pack ()
-#pragma pack (push, 4)
-
OpenPOWER on IntegriCloud