diff options
author | Eric Fiselier <eric@efcs.ca> | 2019-04-24 02:23:30 +0000 |
---|---|---|
committer | Eric Fiselier <eric@efcs.ca> | 2019-04-24 02:23:30 +0000 |
commit | add16a8da9ccd07eabda2dffd0d32188f07da09c (patch) | |
tree | 4e300d103314248bfc7caf19a91ee8b872c78210 /llvm/tools/llvm-symbolizer/llvm-symbolizer.cpp | |
parent | 42a22370f2b7d83b9041498831fce804c1659628 (diff) | |
download | bcm5719-llvm-add16a8da9ccd07eabda2dffd0d32188f07da09c.tar.gz bcm5719-llvm-add16a8da9ccd07eabda2dffd0d32188f07da09c.zip |
[Builtins] Implement __builtin_is_constant_evaluated for use in C++2a
Summary:
This patch implements `__builtin_is_constant_evaluated` as specifier by [P0595R2](https://wg21.link/p0595r2). It is built on the back of Bill Wendling's work for `__builtin_constant_p()`.
More tests to come, but early feedback is appreciated.
I plan to implement warnings for common mis-usages like those belowe in a following patch:
```
void foo(int x) {
if constexpr (std::is_constant_evaluated())) { // condition is always `true`. Should use plain `if` instead.
foo_constexpr(x);
} else {
foo_runtime(x);
}
}
```
Reviewers: rsmith, MaskRay, bruno, void
Reviewed By: rsmith
Subscribers: dexonsmith, zoecarver, fdeazeve, kristina, cfe-commits
Differential Revision: https://reviews.llvm.org/D55500
llvm-svn: 359067
Diffstat (limited to 'llvm/tools/llvm-symbolizer/llvm-symbolizer.cpp')
0 files changed, 0 insertions, 0 deletions