[prev in list] [next in list] [prev in thread] [next in thread] 

List:       gcc-fortran
Subject:    Re: [PATCH] Fortran: fix passing of optional dummies to bind(c) procedures [PR113866]
From:       Harald Anlauf <anlauf () gmx ! de>
Date:       2024-02-13 19:28:00
Message-ID: 7b1c29cd-b949-47f1-88ef-9acc058302ad () gmx ! de
[Download RAW message or body]

Am 13.02.24 um 19:13 schrieb Harald Anlauf:
> indeed the new testcase just regressed due to commit
> r14-8947-g6caec7d9ec37e6 ... :-(
>
> Reduced testcase which fails on trunk:
>
> program p
>     implicit none
>     integer, parameter :: n = 100, l = 10
>     character(l) :: a = 'a234567890', b(n) = 'bcdefghijk'
>     character(:), allocatable :: d, e(:)
>     allocate (d, source=a)
>     allocate (e, source=b)
>     print *, len (d), len (e), size (e)
>     call not_bindc_optional_deferred (d, e)
>     deallocate (d, e)
> contains
>     subroutine not_bindc_optional_deferred (c5, c6)
>         character(:), allocatable, optional :: c5, c6(:)
>         if (.not. present (c5) .or. .not. present (c6)) stop 6
>         print *, len (c5), len (c6), size (c6)
>         if (len (c5) /= l .or. len (c6) /= l) stop 84
>     end
> end
>
> Expected:
>
>                     10                   10                 100
>                     10                   10                 100
>
> After above commit:
>
>                     10                   10                 100
>                     10                     0                 100
> STOP 84

This is now tracked as::

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

> Will have to wait until the cause is found and fixed...

As it is sufficient to disable the deferred-length test,
I've done that and pushed the amended patch as

https://gcc.gnu.org/g:f4935df217ad89f884f908f39086b322e80123d0

Thanks,
Harald


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic