|
|
|
subroutine psb_get_ovrlap(ovrel,desc,info)
|
|
|
|
use psb_descriptor_type
|
|
|
|
use psb_realloc_mod
|
|
|
|
use psb_error_mod
|
|
|
|
implicit none
|
|
|
|
integer, allocatable :: ovrel(:)
|
|
|
|
type(psb_desc_type), intent(in) :: desc
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
|
|
|
integer :: i,j, err_act
|
|
|
|
character(len=20) :: name
|
|
|
|
|
|
|
|
info = 0
|
|
|
|
name='psi_get_overlap'
|
|
|
|
call psb_erractionsave(err_act)
|
|
|
|
|
|
|
|
if (.not.psb_is_asb_desc(desc)) then
|
|
|
|
info = 1122
|
|
|
|
call psb_errorpush(info,name)
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
|
|
|
|
i=0
|
|
|
|
j=1
|
|
|
|
do while(desc%ovrlap_elem(j) /= -1)
|
|
|
|
i = i +1
|
|
|
|
j = j + 2
|
|
|
|
enddo
|
|
|
|
|
|
|
|
if (i > 0) then
|
|
|
|
|
|
|
|
allocate(ovrel(i),stat=info)
|
|
|
|
if (info /= 0 ) then
|
|
|
|
info = 4000
|
|
|
|
call psb_errpush(info,name)
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
|
|
|
|
i=0
|
|
|
|
j=1
|
|
|
|
do while(desc%ovrlap_elem(j) /= -1)
|
|
|
|
i = i +1
|
|
|
|
ovrel(i) = desc%ovrlap_elem(j)
|
|
|
|
j = j + 2
|
|
|
|
enddo
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
if (allocated(ovrel)) then
|
|
|
|
deallocate(ovrel,stat=info)
|
|
|
|
if (info /= 0) then
|
|
|
|
call psb_errpush(4010,name,a_err='Deallocate')
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
call psb_erractionrestore(err_act)
|
|
|
|
return
|
|
|
|
|
|
|
|
9999 continue
|
|
|
|
call psb_erractionrestore(err_act)
|
|
|
|
if (err_act.eq.psb_act_abort_) then
|
|
|
|
call psb_error()
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
return
|
|
|
|
|
|
|
|
end subroutine psb_get_ovrlap
|