summaryrefslogtreecommitdiffstats
path: root/clang/test/PCH/pragma-ms_struct.cpp
diff options
context:
space:
mode:
authorNico Weber <nicolasweber@gmx.de>2016-03-02 23:22:00 +0000
committerNico Weber <nicolasweber@gmx.de>2016-03-02 23:22:00 +0000
commit779355f96bd5e6bff40bae824f3f13ccbb30d018 (patch)
treef8303aa2cdd6b397592c67d67b5244ce181a9628 /clang/test/PCH/pragma-ms_struct.cpp
parent8226fc482999342e899db0d046ad044ba2ada136 (diff)
downloadbcm5719-llvm-779355f96bd5e6bff40bae824f3f13ccbb30d018.tar.gz
bcm5719-llvm-779355f96bd5e6bff40bae824f3f13ccbb30d018.zip
Serialize `pragma ms_struct` state.
pragma ms_struct has an effect on struct decls, and the effect is serialized correctly already. But the "is ms_struct currently on" state wasn't before this change. This uses the same approach as `pragma clang optimize`: When writing a module, the state isn't serialized, only when writing a pch file. llvm-svn: 262539
Diffstat (limited to 'clang/test/PCH/pragma-ms_struct.cpp')
-rw-r--r--clang/test/PCH/pragma-ms_struct.cpp41
1 files changed, 41 insertions, 0 deletions
diff --git a/clang/test/PCH/pragma-ms_struct.cpp b/clang/test/PCH/pragma-ms_struct.cpp
new file mode 100644
index 00000000000..ac2a1e87b23
--- /dev/null
+++ b/clang/test/PCH/pragma-ms_struct.cpp
@@ -0,0 +1,41 @@
+// Test this without pch.
+// RUN: %clang_cc1 %s -Wunknown-pragmas -Werror -triple i386-apple-darwin9 -fsyntax-only -include %s -verify -std=c++11
+
+// Test with pch.
+// RUN: %clang_cc1 %s -Wunknown-pragmas -Werror -triple i386-apple-darwin9 -emit-pch -o %t -std=c++11
+// RUN: %clang_cc1 %s -Wunknown-pragmas -Werror -triple i386-apple-darwin9 -fsyntax-only -include-pch %t -verify -std=c++11
+
+// The first run line creates a pch, and since at that point HEADER is not
+// defined, the only thing contained in the pch is the pragma. The second line
+// then includes that pch, so HEADER is defined and the actual code is compiled.
+// The check then makes sure that the pragma is in effect in the file that
+// includes the pch.
+
+// expected-no-diagnostics
+
+#ifndef HEADER
+#define HEADER
+struct SOffH {
+ short m : 9;
+ int q : 12;
+};
+
+#pragma ms_struct on
+
+struct SOnH {
+ short m : 9;
+ int q : 12;
+};
+
+#else
+
+struct SOnC {
+ short m : 9;
+ int q : 12;
+};
+
+static_assert(sizeof(SOffH) == 4, "");
+static_assert(sizeof(SOnH) == 8, "");
+static_assert(sizeof(SOnC) == 8, "");
+
+#endif
OpenPOWER on IntegriCloud