[Development] Disavowing the Lakos Rule for Q_ASSERT
Thiago Macieira
thiago.macieira at intel.com
Tue Aug 27 01:18:17 CEST 2024
On Monday 26 August 2024 13:12:55 GMT-7 Thiago Macieira wrote:
> "Q_ASSERT don't affect noexceptness"
>
> Or
>
> "noexcept(false) if you call other, noexcept(false) functions from your
> code", which includes all the pthread cancellation points in glibc. Since
> qt_assert is noexcept, Q_ASSERT is not included. This is very easy to
> implement with a static checker.
>
> We could be more complex, with "Q_ASSERT that check preconditions imply
> noexcept(false) but Q_ASSERT that verify the state of the internal invariant
> against corruption don't". This would not be easy to implement with a
> static checker.
What is the rule for dereferencing pointers?
Imagine a function that does:
Q_ASSERT(d);
d->i = b;
is that noexcept? Or is that a precondition?
What happens if I delete the Q_ASSERT? Obviously they aren't necessary,
because they already do disappear on release mode.
On Windows, crashes are delivered as Structured Exceptions, which someone
could convert in to C++ exceptions. So is any function that dereferences a
pointer using a narrow contract?
--
Thiago Macieira - thiago.macieira (AT) intel.com
Principal Engineer - Intel DCAI Platform & System Engineering
-------------- next part --------------
A non-text attachment was scrubbed...
Name: smime.p7s
Type: application/pkcs7-signature
Size: 5152 bytes
Desc: not available
URL: <http://lists.qt-project.org/pipermail/development/attachments/20240826/318b437e/attachment.bin>
More information about the Development
mailing list