summaryrefslogtreecommitdiffstats
path: root/clang/test/Modules/lambda-context.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'clang/test/Modules/lambda-context.cpp')
-rw-r--r--clang/test/Modules/lambda-context.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/clang/test/Modules/lambda-context.cpp b/clang/test/Modules/lambda-context.cpp
new file mode 100644
index 00000000000..6ce482c2b76
--- /dev/null
+++ b/clang/test/Modules/lambda-context.cpp
@@ -0,0 +1,22 @@
+// RUN: %clang_cc1 -fmodules -std=c++11 -emit-pch -o %t %s
+// RUN: %clang_cc1 -fmodules -std=c++11 -include-pch %t %s -verify
+//
+// This test checks for a bug in the deserialization code that was only
+// reachable with modules enabled, but actually building and using modules is
+// not necessary in order to trigger it, so we just use PCH here to make the
+// test simpler.
+
+#ifndef HEADER_INCLUDED
+#define HEADER_INCLUDED
+
+struct X { template <typename T> X(T) {} };
+struct Y { Y(X x = [] {}); };
+
+#else
+
+// This triggers us to load the specialization of X::X for Y's lambda. That
+// lambda's context decl must not be loaded as a result of loading the lambda,
+// as that would hit a deserialization cycle.
+X x = [] {}; // expected-no-diagnostics
+
+#endif
OpenPOWER on IntegriCloud