1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
module write_10_m
type :: mytype
character(len=:), allocatable :: raw
end type
interface write(unformatted)
module procedure :: my_write
end interface
interface read(unformatted)
module procedure :: my_read
end interface
contains
subroutine my_write(x, unit, iostat, iomsg)
class(mytype), intent(in) :: x
integer, intent(in) :: unit
integer, intent(out) :: iostat
character(len=*), intent(inout) :: iomsg
write(unit, iostat=iostat, iomsg=iomsg) len(x%raw)
print *, "Writing length:", len(x%raw)
if (len(x%raw) /= 5) error stop
end subroutine
subroutine my_read(x, unit, iostat, iomsg)
class(mytype), intent(inout) :: x
integer, intent(in) :: unit
integer, intent(out) :: iostat
character(len=*), intent(inout) :: iomsg
integer :: l
read(unit, iostat=iostat, iomsg=iomsg) l
allocate(character(len=l) :: x%raw)
end subroutine
end module write_10_m
program write_10
use write_10_m
implicit none
type(mytype) :: x, y
integer :: u, iostat
character(len=100) :: iomsg
x%raw = "hello"
open(newunit=u, form="unformatted", status="scratch")
write(u, iostat=iostat, iomsg=iomsg) x
print *, len(x%raw)
if (len(x%raw) /= 5) error stop
rewind(u)
read(u, iostat=iostat, iomsg=iomsg) y
print *, len(y%raw)
if (len(y%raw) /= 5) error stop
close(u)
end program write_10
|