diff options
author | David Majnemer <david.majnemer@gmail.com> | 2015-02-26 00:57:33 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2015-02-26 00:57:33 +0000 |
commit | 5123664431100b019a989248e54d4c89b2cd05f9 (patch) | |
tree | 5dc1627021535c1a3bc66f94cf6f84ef2026988e /clang/test/Parser/MicrosoftExtensions.cpp | |
parent | e2008ae475a06972854fc0fee233b0a0495b1e77 (diff) | |
download | bcm5719-llvm-5123664431100b019a989248e54d4c89b2cd05f9.tar.gz bcm5719-llvm-5123664431100b019a989248e54d4c89b2cd05f9.zip |
Sema: __assume with side effects shouldn't result in invalid AST nodes
We'd diagnose an __assume expression which contained a function call.
This would result in us wrongly returning ExprError, causing mysterious
failures later on.
llvm-svn: 230597
Diffstat (limited to 'clang/test/Parser/MicrosoftExtensions.cpp')
-rw-r--r-- | clang/test/Parser/MicrosoftExtensions.cpp | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/clang/test/Parser/MicrosoftExtensions.cpp b/clang/test/Parser/MicrosoftExtensions.cpp index 42689d141f7..736e69a9654 100644 --- a/clang/test/Parser/MicrosoftExtensions.cpp +++ b/clang/test/Parser/MicrosoftExtensions.cpp @@ -1,4 +1,4 @@ -// RUN: %clang_cc1 %s -triple i386-mingw32 -std=c++11 -fsyntax-only -Wno-unused-getter-return-value -Wno-unused-value -Wmicrosoft -verify -fms-extensions -fms-compatibility -fdelayed-template-parsing +// RUN: %clang_cc1 %s -triple i386-mingw32 -std=c++14 -fsyntax-only -Wno-unused-getter-return-value -Wno-unused-value -Wmicrosoft -verify -fms-extensions -fms-compatibility -fdelayed-template-parsing /* Microsoft attribute tests */ [repeatable][source_annotation_attribute( Parameter|ReturnValue )] @@ -375,3 +375,19 @@ typedef void(*ignored_quals_dummy3)(), __stdcall ignored_quals3; // expected-war typedef void(*ignored_quals_dummy4)(), __thiscall ignored_quals4; // expected-warning {{qualifiers after comma in declarator list are ignored}} typedef void(*ignored_quals_dummy5)(), __cdecl ignored_quals5; // expected-warning {{qualifiers after comma in declarator list are ignored}} typedef void(*ignored_quals_dummy6)(), __vectorcall ignored_quals6; // expected-warning {{qualifiers after comma in declarator list are ignored}} + +namespace { +bool f(int); +template <typename T> +struct A { + constexpr A(T t) { + __assume(f(t)); // expected-warning{{the argument to '__assume' has side effects that will be discarded}} + } + constexpr bool g() { return false; } +}; +constexpr A<int> h() { + A<int> b(0); // expected-note {{in instantiation of member function}} + return b; +} +static_assert(h().g() == false, ""); +} |