From 3e3696bf467debb19f413642c49c14df839a584a Mon Sep 17 00:00:00 2001 From: Aaron Ballman Date: Thu, 29 Nov 2018 12:45:50 +0000 Subject: [PATCH] Adding a FIXME test to document an area for improvement with the cert-err58-cpp check; NFC. llvm-svn: 347860 --- .../test/clang-tidy/cert-static-object-exception.cpp | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/clang-tools-extra/test/clang-tidy/cert-static-object-exception.cpp b/clang-tools-extra/test/clang-tidy/cert-static-object-exception.cpp index 5c07c8d..b915252 100644 --- a/clang-tools-extra/test/clang-tidy/cert-static-object-exception.cpp +++ b/clang-tools-extra/test/clang-tidy/cert-static-object-exception.cpp @@ -260,4 +260,16 @@ auto Okay4 = []{ U u; return u.getBadLambda(); }(); auto NotOkay3 = []() noexcept { U u; return u.getBadLambda(); }()(); // Because the lambda returned and called is not noexcept // CHECK-EXCEPTIONS: :[[@LINE-1]]:6: warning: initialization of 'NotOkay3' with static storage duration may throw an exception that cannot be caught [cert-err58-cpp] // CHECK-EXCEPTIONS: :[[@LINE-6]]:12: note: possibly throwing function declared here + +#ifndef NONEXCEPTIONS +struct Bad { + Bad() { + throw 12; + } +}; + +static auto NotOkay4 = [bad = Bad{}](){}; +// FIXME: the above should be diagnosed because the capture init can trigger +// an exception when constructing the Bad object. +#endif // NONEXCEPTIONS } -- 2.7.4