Commit 2423a75a by Jerry DeLisle

re PR fortran/65996 (gfortran ICE with -dH)

2016-01-21  Jerry DeLisle  <jvdelisle@gcc.gnu.org>

	PR fortran/65996
	* error.c (gfc_error): Save the state of abort_on_error and set
	it to false for buffered errors to allow normal processing.
	Restore the state before leaving.

2016-01-21  Jerry DeLisle  <jvdelisle@gcc.gnu.org>

	PR fortran/65996
	gfortran.dg/pr65996.f90: New test.

From-SVN: r232707
parent 0a76463f
2016-01-21 Jerry DeLisle <jvdelisle@gcc.gnu.org>
PR fortran/65996
* error.c (gfc_error): Save the state of abort_on_error and set
it to false for buffered errors to allow normal processing.
Restore the state before leaving.
2016-01-19 Martin Jambor <mjambor@suse.cz> 2016-01-19 Martin Jambor <mjambor@suse.cz>
* types.def (BT_FN_VOID_UINT_PTR_INT_PTR): New. * types.def (BT_FN_VOID_UINT_PTR_INT_PTR): New.
......
...@@ -1226,6 +1226,7 @@ gfc_error (const char *gmsgid, va_list ap) ...@@ -1226,6 +1226,7 @@ gfc_error (const char *gmsgid, va_list ap)
{ {
va_list argp; va_list argp;
va_copy (argp, ap); va_copy (argp, ap);
bool saved_abort_on_error = false;
if (warnings_not_errors) if (warnings_not_errors)
{ {
...@@ -1250,10 +1251,14 @@ gfc_error (const char *gmsgid, va_list ap) ...@@ -1250,10 +1251,14 @@ gfc_error (const char *gmsgid, va_list ap)
if (buffered_p) if (buffered_p)
{ {
/* To prevent -dH from triggering an abort on a buffered error,
save abort_on_error and restore it below. */
saved_abort_on_error = global_dc->abort_on_error;
global_dc->abort_on_error = false;
pp->buffer = pp_error_buffer; pp->buffer = pp_error_buffer;
global_dc->fatal_errors = false; global_dc->fatal_errors = false;
/* To prevent -fmax-errors= triggering, we decrease it before /* To prevent -fmax-errors= triggering, we decrease it before
report_diagnostic increases it. */ report_diagnostic increases it. */
--errorcount; --errorcount;
} }
...@@ -1264,6 +1269,8 @@ gfc_error (const char *gmsgid, va_list ap) ...@@ -1264,6 +1269,8 @@ gfc_error (const char *gmsgid, va_list ap)
{ {
pp->buffer = tmp_buffer; pp->buffer = tmp_buffer;
global_dc->fatal_errors = fatal_errors; global_dc->fatal_errors = fatal_errors;
global_dc->abort_on_error = saved_abort_on_error;
} }
va_end (argp); va_end (argp);
......
2016-01-21 Jerry DeLisle <jvdelisle@gcc.gnu.org>
PR fortran/65996
gfortran.dg/pr65996.f90: New test.
2016-01-21 Dominik Vogt <vogt@linux.vnet.ibm.com> 2016-01-21 Dominik Vogt <vogt@linux.vnet.ibm.com>
PR c++/68810 PR c++/68810
* g++.dg/cpp0x/constexpr-reinterpret1.C: Fix line number that is * g++.dg/cpp0x/constexpr-reinterpret1.C: Fix line number that is
expected to generate an error. expected to generate an error.
2016-01-21 Bernd Schmidt <bschmidt@redhat.com> 2016-01-21 Bernd Schmidt <bschmidt@redhat.com>
......
! { dg-do compile }
! { dg-additional-options "-dH" }
! PR 65996.f90. before patch compiler aborted on this program.
program foo
implicit none
character(len=16) :: a,b,c
a="XXX"
b="&
&XXX"
c="XXX &
& XXX"
write(0,*) 'a=',a,' b=',b,' c=',c
endprogram foo
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment