App-SeismicUnixGui

 view release on metacpan or  search on metacpan

lib/App/SeismicUnixGui/fortran/src/readVtop_lower_file.f  view on Meta::CPAN

      subroutine readVtop_lower_file(result,inbound)
         implicit none
!       read a configuration file

      real*4 :: result
      character (len=255) :: inbound, inbound_locked
      character (len=30) :: format1
      integer :: err_msg, ready

      inbound_locked=trim(inbound)//"_locked"
      format1=  "(F7.1)"

!      print *, 'readVtop_lower_file.f, inbound is:', trim(inbound)
!      in case inbound is of a different, but shorter length in main
!      create a temporary, new, lock file

10     open(status='new',unit=30,file=inbound_locked,iostat=ready)

       if (ready.eq.0) then
       open(unit=31,file=trim(inbound),status='old',iostat=err_msg)

 !       check whether file opens data file
         if (err_msg.eq.0) then

!          print *, 'readVtop_lower_file.f'
          read (31,format1) result
!          print *, 'readVtop_lower_file.f, result',result
          close (unit=31)

         else
!          print *,'readVtop_lower_file.f,locked, try again,read =',ready
!         rest a little before trying again
!         call sleep(1)
          go to 10
         end if

!       remove lock file
11      close (status='delete',unit=30,iostat=err_msg)
        if (err_msg.ne.0) then
         go to 11
!         print *, 'readVtop_lower_file.f, err_messg=',err_msg
        end if

       end if
!       print *, 'readVtop_lower_file, result',result
      end subroutine readVtop_lower_file



( run in 1.079 second using v1.01-cache-2.11-cpan-d8267643d1d )