[C++ PATCH] Don't ignore side-effects on decltype(nullptr) typed args passed to ... (PR c++/92992)
Marek Polacek
polacek@redhat.com
Thu Dec 19 20:49:00 GMT 2019
On Thu, Dec 19, 2019 at 12:40:12AM +0100, Jakub Jelinek wrote:
> Hi!
>
> While looking at PR92666, I've spotted a wrong-code issue where we ignore
> any side-effects on arguments passed to ellipsis if they have
> decltype(nullptr) type.
>
> Fixed thusly, bootstrapped/regtested on x86_64-linux and i686-linux, ok for
> trunk and release branches?
Looks fine to me, and reminds me of c++/90473.
> 2019-12-19 Jakub Jelinek <jakub@redhat.com>
>
> PR c++/92992
> * call.c (convert_arg_to_ellipsis): For decltype(nullptr) arguments
> that have side-effects use cp_build_compound_expr.
>
> * g++.dg/cpp0x/nullptr45.C: New test.
>
> --- gcc/cp/call.c.jj 2019-12-17 10:19:51.013282361 +0100
> +++ gcc/cp/call.c 2019-12-18 18:23:01.441357443 +0100
> @@ -7822,7 +7822,12 @@ convert_arg_to_ellipsis (tree arg, tsubs
> arg = convert_to_real_nofold (double_type_node, arg);
> }
> else if (NULLPTR_TYPE_P (arg_type))
> - arg = null_pointer_node;
> + {
> + if (TREE_SIDE_EFFECTS (arg))
> + arg = cp_build_compound_expr (arg, null_pointer_node, complain);
> + else
> + arg = null_pointer_node;
> + }
FWIW, I was wondering if this should be nullptr_node instead but
http://eel.is/c++draft/expr.call#12.sentence-5 says "An argument that has
type cv std::nullptr_t is converted to type void*." Perhaps there should
be a comment to that effect...
--
Marek Polacek • Red Hat, Inc. • 300 A St, Boston, MA
More information about the Gcc-patches
mailing list