@ -882,7 +882,8 @@ subroutine psb_s_csgetblk(imin,imax,a,b,info,&
if ( info == psb_success_ ) call a % a % csget ( imin , imax , acoo , info , &
if ( info == psb_success_ ) call a % a % csget ( imin , imax , acoo , info , &
& jmin , jmax , iren , append , rscale , cscale )
& jmin , jmax , iren , append , rscale , cscale )
if ( info == psb_success_ ) call move_alloc ( acoo , b % a )
! ! $ if ( info == psb_success_ ) call move_alloc ( acoo , b % a )
if ( info == psb_success_ ) call b % mv_from ( acoo )
if ( info / = psb_success_ ) go to 9999
if ( info / = psb_success_ ) go to 9999
call psb_erractionrestore ( err_act )
call psb_erractionrestore ( err_act )
@ -932,9 +933,10 @@ subroutine psb_s_csclip(a,b,info,&
allocate ( acoo , stat = info )
allocate ( acoo , stat = info )
if ( info == psb_success_ ) call a % a % csclip ( acoo , info , &
if ( info == psb_success_ ) call a % a % csclip ( acoo , info , &
& imin , imax , jmin , jmax , rscale , cscale )
& imin , imax , jmin , jmax , rscale , cscale )
if ( info == psb_success_ ) call move_alloc ( acoo , b % a )
! ! $ if ( info == psb_success_ ) call move_alloc ( acoo , b % a )
if ( info == psb_success_ ) call b % mv_from ( acoo )
if ( info / = psb_success_ ) go to 9999
if ( info / = psb_success_ ) go to 9999
call psb_erractionrestore ( err_act )
call psb_erractionrestore ( err_act )
return
return
@ -1022,13 +1024,6 @@ subroutine psb_s_cscnv(a,b,info,type,mold,upd,dupl)
call psb_errpush ( info , name )
call psb_errpush ( info , name )
go to 9999
go to 9999
endif
endif
if ( present ( dupl ) ) then
call b % set_dupl ( dupl )
else if ( a % is_bld ( ) ) then
! Does this make sense at all ? ? Who knows . .
call b % set_dupl ( psb_dupl_def_ )
end if
if ( count ( ( / present ( mold ) , present ( type ) / ) ) > 1 ) then
if ( count ( ( / present ( mold ) , present ( type ) / ) ) > 1 ) then
info = psb_err_many_optional_arg_
info = psb_err_many_optional_arg_
call psb_errpush ( info , name , a_err = 'TYPE, MOLD' )
call psb_errpush ( info , name , a_err = 'TYPE, MOLD' )
@ -1409,8 +1404,8 @@ subroutine psb_s_cp_from(a,b)
use psb_string_mod
use psb_string_mod
use psb_s_mat_mod , psb_protect_name = > psb_s_cp_from
use psb_s_mat_mod , psb_protect_name = > psb_s_cp_from
implicit none
implicit none
class ( psb_sspmat_type ) , intent ( out ) :: a
class ( psb_sspmat_type ) , intent ( out ) :: a
class ( psb_s_base_sparse_mat ) , intent ( in out ) , allocatable :: b
class ( psb_s_base_sparse_mat ) , intent ( in ) :: b
Integer :: err_act , info
Integer :: err_act , info
character ( len = 20 ) :: name = 'clone'
character ( len = 20 ) :: name = 'clone'
logical , parameter :: debug = . false .
logical , parameter :: debug = . false .
@ -2074,6 +2069,7 @@ function psb_s_csnmi(a) result(res)
character ( len = 20 ) :: name = 'csnmi'
character ( len = 20 ) :: name = 'csnmi'
logical , parameter :: debug = . false .
logical , parameter :: debug = . false .
info = psb_success_
call psb_get_erraction ( err_act )
call psb_get_erraction ( err_act )
if ( . not . allocated ( a % a ) ) then
if ( . not . allocated ( a % a ) ) then
info = psb_err_invalid_mat_state_
info = psb_err_invalid_mat_state_
@ -2295,6 +2291,7 @@ subroutine psb_s_get_diag(a,d,info)
character ( len = 20 ) :: name = 'get_diag'
character ( len = 20 ) :: name = 'get_diag'
logical , parameter :: debug = . false .
logical , parameter :: debug = . false .
info = psb_success_
call psb_erractionsave ( err_act )
call psb_erractionsave ( err_act )
if ( . not . allocated ( a % a ) ) then
if ( . not . allocated ( a % a ) ) then
info = psb_err_invalid_mat_state_
info = psb_err_invalid_mat_state_
@ -2333,6 +2330,7 @@ subroutine psb_s_scal(d,a,info)
character ( len = 20 ) :: name = 'scal'
character ( len = 20 ) :: name = 'scal'
logical , parameter :: debug = . false .
logical , parameter :: debug = . false .
info = psb_success_
call psb_erractionsave ( err_act )
call psb_erractionsave ( err_act )
if ( . not . allocated ( a % a ) ) then
if ( . not . allocated ( a % a ) ) then
info = psb_err_invalid_mat_state_
info = psb_err_invalid_mat_state_
@ -2371,6 +2369,7 @@ subroutine psb_s_scals(d,a,info)
character ( len = 20 ) :: name = 'scal'
character ( len = 20 ) :: name = 'scal'
logical , parameter :: debug = . false .
logical , parameter :: debug = . false .
info = psb_success_
call psb_erractionsave ( err_act )
call psb_erractionsave ( err_act )
if ( . not . allocated ( a % a ) ) then
if ( . not . allocated ( a % a ) ) then
info = psb_err_invalid_mat_state_
info = psb_err_invalid_mat_state_