char_pointer_comp_assign.f90

来自「linux下编程用 编译软件」· F90 代码 · 共 32 行

F90
32
字号
! { dg-do run }! This test the fix of PR18283, where assignments of scalar,! character pointer components of derived types caused an ICE.! It also checks that the array counterparts remain operational.! Contributed by Paul Thomas  pault@gcc.gnu.org!program char_pointer_comp_assign  implicit none  type :: dt     character (len=4), pointer :: scalar     character (len=4), pointer :: array(:)  end type dt  type (dt) :: a   character (len=4), target :: scalar_t ="abcd"  character (len=4), target :: array_t(2) = (/"abcd","efgh"/)! Do assignments first  allocate (a%scalar, a%array(2))  a%scalar = scalar_t  if (a%scalar /= "abcd") call abort ()  a%array = array_t  if (any(a%array /= (/"abcd","efgh"/))) call abort ()  deallocate (a%scalar, a%array)! Now do pointer assignments.  a%scalar => scalar_t  if (a%scalar /= "abcd") call abort ()  a%array => array_t  if (any(a%array /= (/"abcd","efgh"/))) call abort ()end program char_pointer_comp_assign

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?