diff --git a/libcxx/docs/DesignDocs/NoexceptPolicy.rst b/libcxx/docs/DesignDocs/NoexceptPolicy.rst new file mode 100644 --- /dev/null +++ b/libcxx/docs/DesignDocs/NoexceptPolicy.rst @@ -0,0 +1,18 @@ +==================== +``noexcept`` Policy +==================== + +Extended applications of ``noexcept`` +------------------------------------------ + +As of version 13 libc++ may mark functions that do not throw (i.e., +"Throws: Nothing") as ``noexcept``. This has two primary consequences: +first, functions might not report precondition violations by throwing. +Second, user-provided functions, such as custom predicates or custom +traits, which throw might not be propagated up to the caller (unless +specified otherwise by the Standard). + +Before version 13, libc++ did not specify whether a function that did not +throw would be marked as ``noexcept``, so users should not rely on any +non-throwing functions to be marked ``noexcept`` (unless the Standard +specifies it). \ No newline at end of file diff --git a/libcxx/docs/UsingLibcxx.rst b/libcxx/docs/UsingLibcxx.rst --- a/libcxx/docs/UsingLibcxx.rst +++ b/libcxx/docs/UsingLibcxx.rst @@ -345,4 +345,4 @@ * ``search`` * ``unique`` * ``upper_bound`` -* ``lock_guard``'s constructors +* ``lock_guard``'s constructors \ No newline at end of file diff --git a/libcxx/docs/index.rst b/libcxx/docs/index.rst --- a/libcxx/docs/index.rst +++ b/libcxx/docs/index.rst @@ -173,6 +173,7 @@ DesignDocs/FeatureTestMacros DesignDocs/ExtendedCXX03Support DesignDocs/UniquePtrTrivialAbi + DesignDocs/NoexceptPolicy * ` design `_ * ` design `_