Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
type(ESMF_KeywordEnforcer), | optional | :: | keywordEnforcer | |||
character(len=*), | intent(in), | optional | :: | name | ||
integer, | intent(out), | optional | :: | rc |
recursive function ESMF_SciCompCreate(keywordEnforcer, name, rc) ! ! !RETURN VALUE: type(ESMF_SciComp) :: ESMF_SciCompCreate ! ! !ARGUMENTS: type(ESMF_KeywordEnforcer), optional:: keywordEnforcer ! must use keywords below character(len=*), intent(in), optional :: name integer, intent(out), optional :: rc ! ! !DESCRIPTION: ! This interface creates an {\tt ESMF\_SciComp} object. ! The return value is the new {\tt ESMF\_SciComp}. ! ! The arguments are: ! \begin{description} ! \item[{[name]}] ! Name of the newly-created {\tt ESMF\_SciComp}. This name can be altered ! from within the {\tt ESMF\_SciComp} code once the initialization routine ! is called. ! \item[{[rc]}] ! Return code; equals {\tt ESMF\_SUCCESS} if there are no errors. ! \end{description} ! !EOP !------------------------------------------------------------------------------ type(ESMF_CompClass), pointer :: compclass ! generic comp type(ESMF_SciComp) :: scomp integer :: localrc ! local error status ! Initialize the pointer to null. nullify(ESMF_SciCompCreate%compp) nullify(compclass) ! initialize return code; assume routine not implemented if (present(rc)) rc = ESMF_RC_NOT_IMPL localrc = ESMF_RC_NOT_IMPL ! Allocate a new comp class allocate(compclass, stat=localrc) if (ESMF_LogFoundAllocError(localrc, msg="compclass", & ESMF_CONTEXT, rcTOReturn=rc)) return ! call Comp method call ESMF_CompConstruct(compclass, ESMF_COMPTYPE_SCI, name, rc=localrc) if (ESMF_LogFoundError(localrc, & ESMF_ERR_PASSTHRU, & ESMF_CONTEXT, rcTOReturn=rc)) then deallocate(compclass) return endif scomp%compp => compclass ! Add reference to this object into ESMF garbage collection table call c_ESMC_VMAddFObject(scomp, ESMF_ID_COMPONENT%objectID) ! Set return values ESMF_SciCompCreate%compp => compclass ESMF_INIT_SET_CREATED(ESMF_SciCompCreate) ! return successfully if (present(rc)) rc = ESMF_SUCCESS end function ESMF_SciCompCreate