[Bug fortran/99561] New: gfortran reports an error for a truncation that is permitted by the standard

michal.paszta at mobica dot com gcc-bugzilla@gcc.gnu.org
Fri Mar 12 13:33:29 GMT 2021


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

            Bug ID: 99561
           Summary: gfortran reports an error for a truncation that is
                    permitted by the standard
           Product: gcc
           Version: 10.2.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: fortran
          Assignee: unassigned at gcc dot gnu.org
          Reporter: michal.paszta at mobica dot com
  Target Milestone: ---

In this line of code:

INTEGER(KIND=1) :: var8 = 257_2

we try to cast an integer of kind 2 (16 bits) onto an integer of kind 1 (8
bits, value up to 256). This will result in a truncation of the value and is
allowed by the Fortran 2018 Standard, see Table 10.9, Fortran 2018 Standard.

$ ~/gcc/trunk/bin/gfortran issue.f90 
issue.f90:17:27:

   17 |   INTEGER(KIND=1) :: var8 = 257_2
      |                           1
Error: Arithmetic overflow converting INTEGER(2) to INTEGER(1) at (1). This
check can be disabled with the option ‘-fno-range-check’

We believe the operation should be allowed. It could warn the programmer about
the truncation, but should not prevent a successful compilation.

The obvious workaround is to follow the suggestion for the error message and
add '-fno-range-check' - in that case I got no warning or error.

The report originates from a flang github issue:
https://github.com/flang-compiler/flang/issues/992 and was pointed out by Bryan
Chan.

I tried gfortran 7.5.0 and 10.2.0 and both acted the same.


More information about the Gcc-bugs mailing list