diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index bed6fdc5f14..3b6cf6c8c3c 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,8 @@ +2002-12-18 Andrew Haley + + * parse.y (patch_invoke): Force evaluation order when `check' is + set. For PR libgcj/8945. + 2002-12-16 Mark Mitchell * gcj.texi: Change version number to 3.4. diff --git a/gcc/java/parse.y b/gcc/java/parse.y index d117368445f..b68eb158ab6 100644 --- a/gcc/java/parse.y +++ b/gcc/java/parse.y @@ -10793,7 +10793,11 @@ patch_invoke (patch, method, args) is NULL. */ if (check != NULL_TREE) { - patch = build (COMPOUND_EXPR, TREE_TYPE (patch), check, patch); + /* We have to call force_evaluation_order now because creating a + COMPOUND_EXPR wraps the arg list in a way that makes it + unrecognizable by force_evaluation_order later. Yuk. */ + patch = build (COMPOUND_EXPR, TREE_TYPE (patch), check, + force_evaluation_order (patch)); TREE_SIDE_EFFECTS (patch) = 1; }