@ -618,7 +618,7 @@ subroutine psb_c_csall(nr,nc,a,info,nz)
use psb_c_base_mat_mod
use psb_c_base_mat_mod
use psb_error_mod
use psb_error_mod
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( out) :: a
class ( psb_cspmat_type ) , intent ( in out) :: a
integer ( psb_ipk_ ) , intent ( in ) :: nr , nc
integer ( psb_ipk_ ) , intent ( in ) :: nr , nc
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( in ) , optional :: nz
integer ( psb_ipk_ ) , intent ( in ) , optional :: nz
@ -629,6 +629,8 @@ subroutine psb_c_csall(nr,nc,a,info,nz)
call psb_get_erraction ( err_act )
call psb_get_erraction ( err_act )
call a % free ( )
info = psb_success_
info = psb_success_
allocate ( psb_c_coo_sparse_mat :: a % a , stat = info )
allocate ( psb_c_coo_sparse_mat :: a % a , stat = info )
if ( info / = psb_success_ ) then
if ( info / = psb_success_ ) then
@ -968,8 +970,8 @@ subroutine psb_c_tril(a,b,info,diag,imin,imax,&
call psb_errpush ( info , name )
call psb_errpush ( info , name )
go to 9999
go to 9999
endif
endif
allocate ( acoo , stat = info )
allocate ( acoo , stat = info )
call b % free ( )
if ( info == psb_success_ ) then
if ( info == psb_success_ ) then
call a % a % tril ( acoo , info , diag , imin , imax , &
call a % a % tril ( acoo , info , diag , imin , imax , &
@ -1023,6 +1025,7 @@ subroutine psb_c_triu(a,b,info,diag,imin,imax,&
endif
endif
allocate ( acoo , stat = info )
allocate ( acoo , stat = info )
call b % free ( )
if ( info == psb_success_ ) then
if ( info == psb_success_ ) then
call a % a % triu ( acoo , info , diag , imin , imax , &
call a % a % triu ( acoo , info , diag , imin , imax , &
@ -1059,7 +1062,7 @@ subroutine psb_c_csclip(a,b,info,&
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( out) :: b
class ( psb_cspmat_type ) , intent ( in out) :: b
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( in ) , optional :: imin , imax , jmin , jmax
integer ( psb_ipk_ ) , intent ( in ) , optional :: imin , imax , jmin , jmax
logical , intent ( in ) , optional :: rscale , cscale
logical , intent ( in ) , optional :: rscale , cscale
@ -1078,7 +1081,7 @@ subroutine psb_c_csclip(a,b,info,&
endif
endif
allocate ( acoo , stat = info )
allocate ( acoo , stat = info )
call b % free ( )
if ( info == psb_success_ ) then
if ( info == psb_success_ ) then
call a % a % csclip ( acoo , info , &
call a % a % csclip ( acoo , info , &
& imin , imax , jmin , jmax , rscale , cscale )
& imin , imax , jmin , jmax , rscale , cscale )
@ -1156,7 +1159,7 @@ subroutine psb_c_cscnv(a,b,info,type,mold,upd,dupl)
use psb_c_mat_mod , psb_protect_name = > psb_c_cscnv
use psb_c_mat_mod , psb_protect_name = > psb_c_cscnv
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( out) :: b
class ( psb_cspmat_type ) , intent ( in out) :: b
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , optional , intent ( in ) :: dupl , upd
integer ( psb_ipk_ ) , optional , intent ( in ) :: dupl , upd
character ( len = * ) , optional , intent ( in ) :: type
character ( len = * ) , optional , intent ( in ) :: type
@ -1177,6 +1180,7 @@ subroutine psb_c_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
call b % free ( )
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' )
@ -1427,7 +1431,7 @@ subroutine psb_c_clip_d(a,b,info)
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( out) :: b
class ( psb_cspmat_type ) , intent ( in out) :: b
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) :: err_act
integer ( psb_ipk_ ) :: err_act
@ -1547,10 +1551,11 @@ subroutine psb_c_mv_from(a,b)
use psb_string_mod
use psb_string_mod
use psb_c_mat_mod , psb_protect_name = > psb_c_mv_from
use psb_c_mat_mod , psb_protect_name = > psb_c_mv_from
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( out) :: a
class ( psb_cspmat_type ) , intent ( in out) :: a
class ( psb_c_base_sparse_mat ) , intent ( inout ) :: b
class ( psb_c_base_sparse_mat ) , intent ( inout ) :: b
integer ( psb_ipk_ ) :: info
integer ( psb_ipk_ ) :: info
call a % free ( )
# if defined ( HAVE_MOLD )
# if defined ( HAVE_MOLD )
allocate ( a % a , mold = b , stat = info )
allocate ( a % a , mold = b , stat = info )
# else
# else
@ -1577,6 +1582,7 @@ subroutine psb_c_cp_from(a,b)
call psb_erractionsave ( err_act )
call psb_erractionsave ( err_act )
info = psb_success_
info = psb_success_
call a % free ( )
!
!
! Note : it is tempting to use SOURCE allocation below ;
! Note : it is tempting to use SOURCE allocation below ;
! however this would run the risk of messing up with data
! however this would run the risk of messing up with data
@ -1610,7 +1616,7 @@ subroutine psb_c_mv_to(a,b)
use psb_c_mat_mod , psb_protect_name = > psb_c_mv_to
use psb_c_mat_mod , psb_protect_name = > psb_c_mv_to
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( inout ) :: a
class ( psb_cspmat_type ) , intent ( inout ) :: a
class ( psb_c_base_sparse_mat ) , intent ( out) :: b
class ( psb_c_base_sparse_mat ) , intent ( in out) :: b
integer ( psb_ipk_ ) :: info
integer ( psb_ipk_ ) :: info
call b % mv_from_fmt ( a % a , info )
call b % mv_from_fmt ( a % a , info )
@ -1625,7 +1631,7 @@ subroutine psb_c_cp_to(a,b)
use psb_c_mat_mod , psb_protect_name = > psb_c_cp_to
use psb_c_mat_mod , psb_protect_name = > psb_c_cp_to
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_c_base_sparse_mat ) , intent ( out) :: b
class ( psb_c_base_sparse_mat ) , intent ( in out) :: b
integer ( psb_ipk_ ) :: info
integer ( psb_ipk_ ) :: info
call b % cp_from_fmt ( a % a , info )
call b % cp_from_fmt ( a % a , info )
@ -1652,7 +1658,7 @@ subroutine psb_cspmat_type_move(a,b,info)
use psb_c_mat_mod , psb_protect_name = > psb_cspmat_type_move
use psb_c_mat_mod , psb_protect_name = > psb_cspmat_type_move
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( inout ) :: a
class ( psb_cspmat_type ) , intent ( inout ) :: a
class ( psb_cspmat_type ) , intent ( out) :: b
class ( psb_cspmat_type ) , intent ( in out) :: b
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) :: err_act
integer ( psb_ipk_ ) :: err_act
@ -1660,6 +1666,7 @@ subroutine psb_cspmat_type_move(a,b,info)
logical , parameter :: debug = . false .
logical , parameter :: debug = . false .
info = psb_success_
info = psb_success_
call b % free ( )
call move_alloc ( a % a , b % a )
call move_alloc ( a % a , b % a )
return
return
@ -1743,7 +1750,7 @@ subroutine psb_c_transp_2mat(a,b)
use psb_c_mat_mod , psb_protect_name = > psb_c_transp_2mat
use psb_c_mat_mod , psb_protect_name = > psb_c_transp_2mat
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( out) :: b
class ( psb_cspmat_type ) , intent ( in out) :: b
integer ( psb_ipk_ ) :: err_act , info
integer ( psb_ipk_ ) :: err_act , info
character ( len = 20 ) :: name = 'transp'
character ( len = 20 ) :: name = 'transp'
@ -1756,7 +1763,7 @@ subroutine psb_c_transp_2mat(a,b)
call psb_errpush ( info , name )
call psb_errpush ( info , name )
go to 9999
go to 9999
endif
endif
call b % free ( )
# if defined ( HAVE_MOLD )
# if defined ( HAVE_MOLD )
allocate ( b % a , mold = a % a , stat = info )
allocate ( b % a , mold = a % a , stat = info )
# else
# else
@ -1824,7 +1831,7 @@ subroutine psb_c_transc_2mat(a,b)
use psb_c_mat_mod , psb_protect_name = > psb_c_transc_2mat
use psb_c_mat_mod , psb_protect_name = > psb_c_transc_2mat
implicit none
implicit none
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( in ) :: a
class ( psb_cspmat_type ) , intent ( out) :: b
class ( psb_cspmat_type ) , intent ( in out) :: b
integer ( psb_ipk_ ) :: err_act , info
integer ( psb_ipk_ ) :: err_act , info
character ( len = 20 ) :: name = 'transc'
character ( len = 20 ) :: name = 'transc'
@ -1837,7 +1844,7 @@ subroutine psb_c_transc_2mat(a,b)
call psb_errpush ( info , name )
call psb_errpush ( info , name )
go to 9999
go to 9999
endif
endif
call b % free ( )
# if defined ( HAVE_MOLD )
# if defined ( HAVE_MOLD )
allocate ( b % a , mold = a % a , stat = info )
allocate ( b % a , mold = a % a , stat = info )
# else
# else