Skip to content

Commit

Permalink
fix IDM loading of exchanges (MODFLOW-USGS#1577)
Browse files Browse the repository at this point in the history
  • Loading branch information
mjr-deltares authored Jan 26, 2024
1 parent f2c9ebb commit 2996ac0
Showing 1 changed file with 23 additions and 7 deletions.
30 changes: 23 additions & 7 deletions src/Utilities/Idm/IdmLoad.f90
Original file line number Diff line number Diff line change
Expand Up @@ -269,7 +269,8 @@ end subroutine load_models
subroutine load_exchanges(model_loadmask, iout)
! -- modules
use MemoryHelperModule, only: create_mem_path
use MemoryManagerModule, only: mem_setptr, mem_allocate, mem_deallocate
use MemoryManagerModule, only: mem_setptr, mem_allocate, &
mem_deallocate, get_isize
use CharacterStringModule, only: CharacterStringType
use SimVariablesModule, only: idm_context, simfile
use SourceCommonModule, only: idm_subcomponent_type, ifind_charstr
Expand Down Expand Up @@ -301,7 +302,7 @@ subroutine load_exchanges(model_loadmask, iout)
character(len=LENCOMPONENTNAME) :: sc_type, sc_name, mtype
class(StaticPkgLoadBaseType), pointer :: static_loader
class(DynamicPkgLoadBaseType), pointer :: dynamic_loader
integer(I4B) :: n, m1_idx, m2_idx, irem
integer(I4B) :: n, m1_idx, m2_idx, irem, isize
!
! -- set input memory path
input_mempath = create_mem_path('SIM', 'NAM', idm_context)
Expand Down Expand Up @@ -360,8 +361,13 @@ subroutine load_exchanges(model_loadmask, iout)
mfname = mfnames(irem)
mname = mnames(irem)
mempath = create_mem_path(component=mname, context=idm_context)
call mem_allocate(ncelldim, 'NCELLDIM', mempath)
ncelldim = remote_model_ndim(mtype, mfname)
call get_isize('NCELLDIM', mempath, isize)
if (isize < 0) then
call mem_allocate(ncelldim, 'NCELLDIM', mempath)
ncelldim = remote_model_ndim(mtype, mfname)
else
call mem_setptr(ncelldim, 'NCELLDIM', mempath)
end if
else
nullify (ncelldim)
end if
Expand Down Expand Up @@ -393,13 +399,23 @@ subroutine load_exchanges(model_loadmask, iout)
deallocate (static_loader)
end if
!
! -- deallocate ncelldim as all input has been loaded
if (associated(ncelldim)) call mem_deallocate(ncelldim)
!
end if
!
end do
!
! -- clean up temporary NCELLDIM for remote models
do n = 1, size(mnames)
if (model_loadmask(n) == 0) then
mname = mnames(n)
mempath = create_mem_path(component=mname, context=idm_context)
call get_isize('NCELLDIM', mempath, isize)
if (isize > 0) then
call mem_setptr(ncelldim, 'NCELLDIM', mempath)
call mem_deallocate(ncelldim)
end if
end if
end do
!
! -- return
return
end subroutine load_exchanges
Expand Down

0 comments on commit 2996ac0

Please sign in to comment.