comm_t
pure function m_size_func(this) result(size) class(comm_t), intent(in) :: this integer :: size size = this%m_size end function m_size_func