App-SeismicUnixGui

 view release on metacpan or  search on metacpan

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

      subroutine readVbotNtop_factor_file(result,inbound)
         implicit none
!       read a VbotNtop_factor 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)"
!      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

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

         else
!         print *, 'readVbotNtop_factor_file.f, err_msg=',err_msg
!         rest a little before trying again
!         call sleep(1)
          go to 10
         end if
       else
         print *, 'readVbotNtop_factor_file.f,locked, try again,read =',ready
         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 *, 'readVbotNtop_factor_file.f, err_messg=',err_msg
        end if
!       print *, 'readVbotNtop_factor_file, result',result

      end subroutine readVbotNtop_factor_file



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