Fix error_impl, and add check_error()

newG2L
Salvatore Filippone 4 years ago
parent fdd1da6fa1
commit aeb1397e9f

@ -46,11 +46,14 @@ subroutine psb_par_error_handler(ctxt,err_act)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act == psb_act_print_) & if (err_act == psb_act_print_) then
& call psb_error(ctxt, abrt=.false.) call psb_error(ctxt, abrt=.false.)
if (err_act == psb_act_abort_) & else if (err_act == psb_act_ret_) then
& call psb_error(ctxt, abrt=.true.) ! do nothing
else
call psb_error(ctxt, abrt=.true.)
end if
return return
end subroutine psb_par_error_handler end subroutine psb_par_error_handler

@ -162,6 +162,7 @@ module psb_error_mod
logical, save :: comm_global_checks = .false. logical, save :: comm_global_checks = .false.
contains contains
subroutine psb_set_global_checks(val) subroutine psb_set_global_checks(val)
logical, intent(in), optional :: val logical, intent(in), optional :: val
@ -182,7 +183,16 @@ contains
val = comm_global_checks val = comm_global_checks
end function psb_get_global_checks end function psb_get_global_checks
subroutine psb_check_error(ctxt,abrt)
implicit none
type(psb_ctxt_type), intent(in) :: ctxt
logical, optional, intent(in) :: abrt
if (psb_errstatus_fatal()) then
call psb_error(ctxt,abrt)
end if
end subroutine psb_check_error
! saves action to support error traceback ! saves action to support error traceback
! also changes error action to "return" ! also changes error action to "return"

@ -49,6 +49,7 @@ extern "C" {
void psb_c_check_error(psb_c_ctxt *cctxt);
psb_i_t psb_c_error(); psb_i_t psb_c_error();
psb_i_t psb_c_clean_errstack(); psb_i_t psb_c_clean_errstack();
void psb_c_print_errmsg(); void psb_c_print_errmsg();

@ -132,6 +132,24 @@ contains
return return
end subroutine psb_c_abort end subroutine psb_c_abort
subroutine psb_c_check_error(cctxt) bind(c)
use psb_base_mod, only : psb_init, psb_ctxt_type
implicit none
type(psb_c_object_type) :: cctxt
type(psb_ctxt_type), pointer :: ctxt
integer :: info
if (c_associated(cctxt%item)) then
call c_f_pointer(cctxt%item,ctxt)
deallocate(ctxt,stat=info)
if (info /= 0) return
end if
allocate(ctxt,stat=info)
if (info /= 0) return
call psb_check_error(ctxt,abrt=.true.)
end subroutine psb_c_check_error
subroutine psb_c_info(cctxt,iam,np) bind(c) subroutine psb_c_info(cctxt,iam,np) bind(c)
use psb_base_mod, only : psb_info, psb_ctxt_type use psb_base_mod, only : psb_info, psb_ctxt_type

Loading…
Cancel
Save