https://gcc.gnu.org/bugzilla/show_bug.cgi?id=94323

--- Comment #3 from CVS Commits <cvs-commit at gcc dot gnu.org> ---
The master branch has been updated by Jakub Jelinek <ja...@gcc.gnu.org>:

https://gcc.gnu.org/g:da920d0c46c38fe25ee0b597a8698d3a4d098f3c

commit r10-7397-gda920d0c46c38fe25ee0b597a8698d3a4d098f3c
Author: Jakub Jelinek <ja...@redhat.com>
Date:   Thu Mar 26 10:35:52 2020 +0100

    tree: Fix -fcompare-debug issues due to protected_set_expr_location
[PR94323]

    The following testcase FAILs since recently when the C++ FE started calling
    protected_set_expr_location more often.
    With -g, it is called on a STATEMENT_LIST that contains a DEBUG_BEGIN_STMT
    and CLEANUP_POINT_EXPR, and as STATEMENT_LISTs have !CAN_HAVE_LOCATION_P,
    nothing is set.  Without -g, it is called instead on the CLEANUP_POINT_EXPR
    directly and changes its location.

    The following patch recurses on the single non-DEBUG_BEGIN_STMT statement
    of a STATEMENT_LIST if any to make the two behave the same.

    2020-03-26  Jakub Jelinek  <ja...@redhat.com>

            PR debug/94323
            * tree.c (protected_set_expr_location): Recurse on STATEMENT_LIST
            that contains exactly one non-DEBUG_BEGIN_STMT statement.

            * g++.dg/debug/pr94323.C: New test.

Reply via email to