[clang] 9c8dab0 - [clang] Update the lifetimebound example with up-to-date expected warning and change the sample code to be a fully working example (#113437)
via cfe-commits
cfe-commits at lists.llvm.org
Wed Oct 30 00:59:52 PDT 2024
Author: Boaz Brickner
Date: 2024-10-30T08:59:49+01:00
New Revision: 9c8dab018dee3143c28a7d7f5fdb32385da36101
URL: https://github.com/llvm/llvm-project/commit/9c8dab018dee3143c28a7d7f5fdb32385da36101
DIFF: https://github.com/llvm/llvm-project/commit/9c8dab018dee3143c28a7d7f5fdb32385da36101.diff
LOG: [clang] Update the lifetimebound example with up-to-date expected warning and change the sample code to be a fully working example (#113437)
Tested the code: https://godbolt.org/z/n5xcq65YM
Tested the generated documentation:
![BruDQ2UkTXHA9PE](https://github.com/user-attachments/assets/cf527d1a-ef3b-41f2-84c2-4ca38af16d2d)
Added:
Modified:
clang/include/clang/Basic/AttrDocs.td
Removed:
################################################################################
diff --git a/clang/include/clang/Basic/AttrDocs.td b/clang/include/clang/Basic/AttrDocs.td
index 7a130c434e73ce..fbbfc4acdf391e 100644
--- a/clang/include/clang/Basic/AttrDocs.td
+++ b/clang/include/clang/Basic/AttrDocs.td
@@ -3702,20 +3702,32 @@ user-declared functions. For example:
.. code-block:: c++
+ #include <map>
+ #include <string>
+
+ using namespace std::literals;
+
// Returns m[key] if key is present, or default_value if not.
template<typename T, typename U>
const U &get_or_default(const std::map<T, U> &m [[clang::lifetimebound]],
const T &key, /* note, not lifetimebound */
- const U &default_value [[clang::lifetimebound]]);
+ const U &default_value [[clang::lifetimebound]]) {
+ if (auto iter = m.find(key); iter != m.end()) return iter->second;
+ else return default_value;
+ }
- std::map<std::string, std::string> m;
- // warning: temporary "bar"s that might be bound to local reference 'val'
- // will be destroyed at the end of the full-expression
- const std::string &val = get_or_default(m, "foo"s, "bar"s);
+ int main() {
+ std::map<std::string, std::string> m;
+ // warning: temporary bound to local reference 'val1' will be destroyed
+ // at the end of the full-expression
+ const std::string &val1 = get_or_default(m, "foo"s, "bar"s);
- // No warning in this case.
- std::string def_val = "bar"s;
- const std::string &val = get_or_default(m, "foo"s, def_val);
+ // No warning in this case.
+ std::string def_val = "bar"s;
+ const std::string &val2 = get_or_default(m, "foo"s, def_val);
+
+ return 0;
+ }
The attribute can be applied to the implicit ``this`` parameter of a member
function by writing the attribute after the function type:
More information about the cfe-commits
mailing list