re PR libfortran/27704 (Incorrect runtime error on multiple OPEN)
2006-07-03 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR libgfortran/27704 * runtime/error.c (notify_std): Pass common flags into function. Use flags to show locus of error or warning. * libgfortran.h: Add enum try. Add prototype for notify_std. * io/open.c (edit_modes): Allow status="old" and add extension to allow status="scratch" *io/list_read.c (nml_read_obj): Update call to notify_std. *io/io.h: Remove enum try and prototype for notify_std. *io/transfer.c (read_sf): Update call to notify_std. *io/format.c (parse_format_list): Update call to notify_std. From-SVN: r115168
This commit is contained in:
parent
2b17a9af81
commit
2e4444278c
@ -1,3 +1,16 @@
|
|||||||
|
2006-07-03 Jerry DeLisle <jvdelisle@gcc.gnu.org>
|
||||||
|
|
||||||
|
PR libgfortran/27704
|
||||||
|
* runtime/error.c (notify_std): Pass common flags into function. Use
|
||||||
|
flags to show locus of error or warning.
|
||||||
|
* libgfortran.h: Add enum try. Add prototype for notify_std.
|
||||||
|
* io/open.c (edit_modes): Allow status="old" and add extension to
|
||||||
|
allow status="scratch"
|
||||||
|
*io/list_read.c (nml_read_obj): Update call to notify_std.
|
||||||
|
*io/io.h: Remove enum try and prototype for notify_std.
|
||||||
|
*io/transfer.c (read_sf): Update call to notify_std.
|
||||||
|
*io/format.c (parse_format_list): Update call to notify_std.
|
||||||
|
|
||||||
2006-06-25 Francois-Xavier Coudert <coudert@clipper.ens.fr>
|
2006-06-25 Francois-Xavier Coudert <coudert@clipper.ens.fr>
|
||||||
|
|
||||||
* io/io.h: Move proto for unit_to_fd...
|
* io/io.h: Move proto for unit_to_fd...
|
||||||
|
@ -575,7 +575,7 @@ parse_format_list (st_parameter_dt *dtp)
|
|||||||
case FMT_DOLLAR:
|
case FMT_DOLLAR:
|
||||||
get_fnode (fmt, &head, &tail, FMT_DOLLAR);
|
get_fnode (fmt, &head, &tail, FMT_DOLLAR);
|
||||||
tail->repeat = 1;
|
tail->repeat = 1;
|
||||||
notify_std (GFC_STD_GNU, "Extension: $ descriptor");
|
notify_std (&dtp->common, GFC_STD_GNU, "Extension: $ descriptor");
|
||||||
goto between_desc;
|
goto between_desc;
|
||||||
|
|
||||||
case FMT_T:
|
case FMT_T:
|
||||||
@ -671,7 +671,7 @@ parse_format_list (st_parameter_dt *dtp)
|
|||||||
{
|
{
|
||||||
fmt->saved_token = t;
|
fmt->saved_token = t;
|
||||||
fmt->value = 1; /* Default width */
|
fmt->value = 1; /* Default width */
|
||||||
notify_std(GFC_STD_GNU, posint_required);
|
notify_std (&dtp->common, GFC_STD_GNU, posint_required);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,10 +46,6 @@ typedef enum
|
|||||||
bt;
|
bt;
|
||||||
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{ SUCCESS = 1, FAILURE }
|
|
||||||
try;
|
|
||||||
|
|
||||||
struct st_parameter_dt;
|
struct st_parameter_dt;
|
||||||
|
|
||||||
typedef struct stream
|
typedef struct stream
|
||||||
@ -865,9 +861,6 @@ extern void list_formatted_write (st_parameter_dt *, bt, void *, int, size_t,
|
|||||||
internal_proto(list_formatted_write);
|
internal_proto(list_formatted_write);
|
||||||
|
|
||||||
/* error.c */
|
/* error.c */
|
||||||
extern try notify_std (int, const char *);
|
|
||||||
internal_proto(notify_std);
|
|
||||||
|
|
||||||
extern notification notification_std(int);
|
extern notification notification_std(int);
|
||||||
internal_proto(notification_std);
|
internal_proto(notification_std);
|
||||||
|
|
||||||
|
@ -2214,7 +2214,7 @@ nml_read_obj (st_parameter_dt *dtp, namelist_info * nl, index_type offset,
|
|||||||
and set the flag to zero to prevent further warnings. */
|
and set the flag to zero to prevent further warnings. */
|
||||||
if (dtp->u.p.expanded_read == 2)
|
if (dtp->u.p.expanded_read == 2)
|
||||||
{
|
{
|
||||||
notify_std (GFC_STD_GNU, "Non-standard expanded namelist read.");
|
notify_std (&dtp->common, GFC_STD_GNU, "Non-standard expanded namelist read.");
|
||||||
dtp->u.p.expanded_read = 0;
|
dtp->u.p.expanded_read = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ edit_modes (st_parameter_open *opp, gfc_unit * u, unit_flags * flags)
|
|||||||
{
|
{
|
||||||
/* Complain about attempts to change the unchangeable. */
|
/* Complain about attempts to change the unchangeable. */
|
||||||
|
|
||||||
if (flags->status != STATUS_UNSPECIFIED &&
|
if (flags->status != STATUS_UNSPECIFIED && flags->status != STATUS_OLD &&
|
||||||
u->flags.status != flags->status)
|
u->flags.status != flags->status)
|
||||||
generate_error (&opp->common, ERROR_BAD_OPTION,
|
generate_error (&opp->common, ERROR_BAD_OPTION,
|
||||||
"Cannot change STATUS parameter in OPEN statement");
|
"Cannot change STATUS parameter in OPEN statement");
|
||||||
@ -154,8 +154,14 @@ edit_modes (st_parameter_open *opp, gfc_unit * u, unit_flags * flags)
|
|||||||
|
|
||||||
if (flags->status != STATUS_UNSPECIFIED && flags->status != STATUS_OLD &&
|
if (flags->status != STATUS_UNSPECIFIED && flags->status != STATUS_OLD &&
|
||||||
flags->status != STATUS_UNKNOWN)
|
flags->status != STATUS_UNKNOWN)
|
||||||
generate_error (&opp->common, ERROR_BAD_OPTION,
|
{
|
||||||
|
if (flags->status == STATUS_SCRATCH)
|
||||||
|
notify_std (&opp->common, GFC_STD_GNU,
|
||||||
"OPEN statement must have a STATUS of OLD or UNKNOWN");
|
"OPEN statement must have a STATUS of OLD or UNKNOWN");
|
||||||
|
else
|
||||||
|
generate_error (&opp->common, ERROR_BAD_OPTION,
|
||||||
|
"OPEN statement must have a STATUS of OLD or UNKNOWN");
|
||||||
|
}
|
||||||
|
|
||||||
if (u->flags.form == FORM_UNFORMATTED)
|
if (u->flags.form == FORM_UNFORMATTED)
|
||||||
{
|
{
|
||||||
@ -615,7 +621,7 @@ st_open (st_parameter_open *opp)
|
|||||||
"Conflicting ACCESS and POSITION flags in"
|
"Conflicting ACCESS and POSITION flags in"
|
||||||
" OPEN statement");
|
" OPEN statement");
|
||||||
|
|
||||||
notify_std (GFC_STD_GNU,
|
notify_std (&opp->common, GFC_STD_GNU,
|
||||||
"Extension: APPEND as a value for ACCESS in OPEN statement");
|
"Extension: APPEND as a value for ACCESS in OPEN statement");
|
||||||
flags.access = ACCESS_SEQUENTIAL;
|
flags.access = ACCESS_SEQUENTIAL;
|
||||||
flags.position = POSITION_APPEND;
|
flags.position = POSITION_APPEND;
|
||||||
|
@ -220,7 +220,8 @@ read_sf (st_parameter_dt *dtp, int *length, int no_error)
|
|||||||
if (*q == ',')
|
if (*q == ',')
|
||||||
if (dtp->u.p.sf_read_comma == 1)
|
if (dtp->u.p.sf_read_comma == 1)
|
||||||
{
|
{
|
||||||
notify_std (GFC_STD_GNU, "Comma in formatted numeric read.");
|
notify_std (&dtp->common, GFC_STD_GNU,
|
||||||
|
"Comma in formatted numeric read.");
|
||||||
*length = n;
|
*length = n;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -414,6 +414,11 @@ typedef enum
|
|||||||
{ SILENT, WARNING, ERROR }
|
{ SILENT, WARNING, ERROR }
|
||||||
notification;
|
notification;
|
||||||
|
|
||||||
|
/* This is returned by notify_std and several io functions. */
|
||||||
|
typedef enum
|
||||||
|
{ SUCCESS = 1, FAILURE }
|
||||||
|
try;
|
||||||
|
|
||||||
/* The filename and line number don't go inside the globals structure.
|
/* The filename and line number don't go inside the globals structure.
|
||||||
They are set by the rest of the program and must be linked to. */
|
They are set by the rest of the program and must be linked to. */
|
||||||
|
|
||||||
@ -492,6 +497,9 @@ internal_proto(translate_error);
|
|||||||
extern void generate_error (struct st_parameter_common *, int, const char *);
|
extern void generate_error (struct st_parameter_common *, int, const char *);
|
||||||
internal_proto(generate_error);
|
internal_proto(generate_error);
|
||||||
|
|
||||||
|
extern try notify_std (struct st_parameter_common *, int, const char *);
|
||||||
|
internal_proto(notify_std);
|
||||||
|
|
||||||
/* fpu.c */
|
/* fpu.c */
|
||||||
|
|
||||||
extern void set_fpu (void);
|
extern void set_fpu (void);
|
||||||
|
@ -527,7 +527,7 @@ notification_std (int std)
|
|||||||
standard does not contain the requested bits. */
|
standard does not contain the requested bits. */
|
||||||
|
|
||||||
try
|
try
|
||||||
notify_std (int std, const char * message)
|
notify_std (st_parameter_common *cmp, int std, const char * message)
|
||||||
{
|
{
|
||||||
int warning;
|
int warning;
|
||||||
|
|
||||||
@ -540,10 +540,15 @@ notify_std (int std, const char * message)
|
|||||||
|
|
||||||
if (!warning)
|
if (!warning)
|
||||||
{
|
{
|
||||||
|
recursion_check ();
|
||||||
|
show_locus (cmp);
|
||||||
st_printf ("Fortran runtime error: %s\n", message);
|
st_printf ("Fortran runtime error: %s\n", message);
|
||||||
sys_exit (2);
|
sys_exit (2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
st_printf ("Fortran runtime warning: %s\n", message);
|
{
|
||||||
|
show_locus (cmp);
|
||||||
|
st_printf ("Fortran runtime warning: %s\n", message);
|
||||||
|
}
|
||||||
return FAILURE;
|
return FAILURE;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user