FIX: Substring Concatenation in Test Generates Incorrect Code

ID: Q39849

4.10 5.00 5.10 MS-DOS kbusage kbfixlist kbbuglist

The information in this article applies to:

SYMPTOMS

The following FORTRAN program produces incorrect results and causes the machine to hang:

        CHARACTER STRNG1*9, STRNG2*9
        INTEGER N
        LOGICAL SAME
        N=4
        STRNG1 = '123456789'
        STRNG2 = 'ABCDEFGHI'
        SAME = 'ZZ'//STRNG1(1:N) .EQ. STRNG2(1:N+2)
        WRITE(*,*) 'ZZ'//STRNG1(1:N)
        WRITE(*,*) STRNG2(1:N+2)
        WRITE(*,*) SAME
        END

The correct output should be as follows:

       ZZ1234
       ABCDEF
       F

The actual output is as follows:

       ZZ1234
       ABCDEF
       T

CAUSE

The code causes the machine to hang. Compiling without optimization had no effect. The problem is that bad code is generated for the substrings on the logical test line. Here the two substrings must be evaluated and incorrect code is being generated. If "N" in the concatenated substring is replaced with the numerical equivalent "4" or if the concatenation is executed previously and a temporary variable is used for the logical test, correct code is generated and everything executes correctly.

It has been reported that this code does not hang the system right away. You can execute internal MS-DOS commands, but as soon as you try any external commands, the system hangs.

STATUS

Microsoft has confirmed this to be a problem in the Microsoft products listed at the beginning of this article. This problem was corrected in FORTRAN PowerStation.

Additional reference words: 4.10 5.00 5.10 KBCategory: kbusage kbfixlist kbbuglist KBSubcategory: FLIss Solution Type : kbfix

Last Reviewed: April 30, 1998