aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/simplify.c
diff options
context:
space:
mode:
authorHarald Anlauf <anlauf@gmx.de>2021-08-20 13:38:00 +0200
committerHarald Anlauf <anlauf@gmx.de>2021-08-20 13:38:00 +0200
commit12f22906d3c025e7edb60e3264dc9cd27a49e3e1 (patch)
treea93a54e48136d735c7b432327488aa24fc2bce96 /gcc/fortran/simplify.c
parent37744f8260857005c8409c9e2e633a05c768a7dd (diff)
downloadgcc-12f22906d3c025e7edb60e3264dc9cd27a49e3e1.zip
gcc-12f22906d3c025e7edb60e3264dc9cd27a49e3e1.tar.gz
gcc-12f22906d3c025e7edb60e3264dc9cd27a49e3e1.tar.bz2
Fortran - use temporary char buffer for passing HOST_WIDE_INT to gfc_error
gcc/fortran/ChangeLog: PR fortran/100950 * simplify.c (substring_has_constant_len): Fix format string of gfc_error, pass HOST_WIDE_INT bounds values via char buffer.
Diffstat (limited to 'gcc/fortran/simplify.c')
-rw-r--r--gcc/fortran/simplify.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/gcc/fortran/simplify.c b/gcc/fortran/simplify.c
index 492867e..eaabbff 100644
--- a/gcc/fortran/simplify.c
+++ b/gcc/fortran/simplify.c
@@ -4552,11 +4552,12 @@ substring_has_constant_len (gfc_expr *e)
if (istart <= iend)
{
+ char buffer[21];
if (istart < 1)
{
- gfc_error ("Substring start index (" HOST_WIDE_INT_PRINT_DEC
- ") at %L below 1",
- istart, &ref->u.ss.start->where);
+ sprintf (buffer, HOST_WIDE_INT_PRINT_DEC, istart);
+ gfc_error ("Substring start index (%s) at %L below 1",
+ buffer, &ref->u.ss.start->where);
return false;
}
@@ -4567,9 +4568,9 @@ substring_has_constant_len (gfc_expr *e)
length = gfc_mpz_get_hwi (ref->u.ss.length->length->value.integer);
if (iend > length)
{
- gfc_error ("Substring end index (" HOST_WIDE_INT_PRINT_DEC
- ") at %L exceeds string length",
- iend, &ref->u.ss.end->where);
+ sprintf (buffer, HOST_WIDE_INT_PRINT_DEC, iend);
+ gfc_error ("Substring end index (%s) at %L exceeds string length",
+ buffer, &ref->u.ss.end->where);
return false;
}
length = iend - istart + 1;