FWIW, GCC does warn on similar code - the reason it doesn't warn here is
that the function is `inline` and never called, so GCC probably never
analyses it (I pasted your code here and added a few cases to demonstrate
GCC's quirks compared to Clang's here: https://godbolt.org/z/YM9q91bx1 )

So far as I can tell, noreturn isn't carried on function types, so it isn't
possible to do what you want at the moment. That's my rough understanding,
at least.

On Thu, Jan 6, 2022 at 5:23 PM Manu agarwal via cfe-users <
cfe-users@lists.llvm.org> wrote:

> Hi,
>
> We have the below code where this warning gets generated.
>
> #include    <iostream>
>
>
>
> [[noreturn]] inline void
>
> abc () noexcept
>
> {
>
>     std::terminate ();
>
> }
>
>
>
> using MyNoReturn = void (*) () noexcept;
>
>  //using MyNoReturn = std::add_pointer_t<decltype(abc)>;    *// even this
> declaration, instead of the above, gives the same warning*
>
>
>
> [[noreturn]]
>
> inline void IDontReturn () noexcept
>
> {
>
>     std::terminate ();
>
> }
>
>
> static MyNoReturn   gvar {IDontReturn};
>
>
>
> [[noreturn]]
>
> inline void
>
> CallIDontReturn () noexcept
>
> {
>
>     gvar ();                                 // *here is where clang
> gives warning: function declared 'noreturn' should not return
> [-Winvalid-noreturn]*
>
> }
>
> We have the used the below command to compile:
> clang++ -std=c++17 -Wall -o runusing usingst.cpp
>
> gcc does not show this warning.
>
> Please let us know how we can use 'using' clause to declare function
> pointer to a function that does not return, so that this warning does not
> show up.
>
> Regards,
> Manu
> _______________________________________________
> cfe-users mailing list
> cfe-users@lists.llvm.org
> https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users
>
_______________________________________________
cfe-users mailing list
cfe-users@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users

Reply via email to