FTMutableObjectArray Derived Type

type, public, extends(FTObject) :: FTMutableObjectArray


Inherits

type~~ftmutableobjectarray~~InheritsGraph type~ftmutableobjectarray FTMutableObjectArray type~ftobject FTObject type~ftmutableobjectarray->type~ftobject type~ftobjectpointerwrapper FTObjectPointerWrapper type~ftmutableobjectarray->type~ftobjectpointerwrapper array type~ftobjectpointerwrapper->type~ftobject object

Finalization Procedures

final :: destructObjectArray

  • public recursive subroutine destructObjectArray(self)

    Destructor for the class. This is called automatically when the reference count reaches zero. Do not call this yourself.

    Arguments

    Type IntentOptional Attributes Name
    type(FTMutableObjectArray) :: self

Type-Bound Procedures

procedure, public :: init => initFTObject

procedure, public :: description => FTObjectDescription

  • public function FTObjectDescription(self)

    Returns a character string of length DESCRIPTION_CHARACTER_LENGTH that represents the object. the base class implementation returns an empty string. Note that if the description is too long, the expected string will be truncated. In general, one wants to use printDescription.

    Arguments

    Type IntentOptional Attributes Name
    class(FTObject) :: self

    Return Value character(len=DESCRIPTION_CHARACTER_LENGTH)

procedure, public, non_overridable :: copy => copyFTObject

  • private function copyFTObject(self) result(copy)

    Base class implementation of the assignment function. Call this from within any subclasses copy assignment function. All FTObject's implementation does is set the reference count to one, implying no additional ownership to the caller that is creating the copy.

    Arguments

    Type IntentOptional Attributes Name
    class(FTObject), intent(in) :: self

    Return Value class(FTObject), POINTER

procedure, public, non_overridable :: retain => retainFTObject

  • public subroutine retainFTObject(self)

    Retain increases the reference count by one and implies ownership to the caller. ### Usage: CALL obj\ % retain()

    Arguments

    Type IntentOptional Attributes Name
    class(FTObject) :: self

procedure, public, non_overridable :: isUnreferenced

  • public function isUnreferenced(self)

    Owners of objects should call isUnreferenced after releasing a pointer object. If true, the object should be deallocated and then set to point to NULL()

    Read more…

    Arguments

    Type IntentOptional Attributes Name
    class(FTObject) :: self

    Return Value logical

procedure, public, non_overridable :: refCount

  • public function refCount(self)

    Returns the reference count for the object. Normally this is done only for debugging purposes.

    Arguments

    Type IntentOptional Attributes Name
    class(FTObject) :: self

    Return Value integer

procedure, public :: initWithSize => initObjectArrayWithSize

procedure, public :: addObject => addObjectToArray

procedure, public :: replaceObjectAtIndexWithObject

procedure, public :: removeObjectAtIndex

procedure, public :: objectAtIndex

procedure, public :: printDescription => printArray

procedure, public :: className => arrayClassName

  • public function arrayClassName(self) result(s)

    Class name returns a string with the name of the type of the object

    Read more…

    Arguments

    Type IntentOptional Attributes Name
    class(FTMutableObjectArray) :: self

    Return Value character(len=CLASS_NAME_CHARACTER_LENGTH)

procedure, public :: setChunkSize

  • public subroutine setChunkSize(self, chunkSize)

    Set the number of items to be added when the array needs to be re-sized

    Read more…

    Arguments

    Type IntentOptional Attributes Name
    class(FTMutableObjectArray) :: self
    integer :: chunkSize

procedure, public :: chunkSize

  • public function chunkSize(self)

    Returns the number of items to be added when the array needs to be re-sized

    Read more…

    Arguments

    Type IntentOptional Attributes Name
    class(FTMutableObjectArray) :: self

    Return Value integer

procedure, public :: COUNT => numberOfItems

procedure, public :: allocatedSize