SeparatorColumn.F90 Source File


This file depends on

sourcefile~~separatorcolumn.f90~~EfferentGraph sourcefile~separatorcolumn.f90 SeparatorColumn.F90 sourcefile~abstractcolumn.f90 AbstractColumn.F90 sourcefile~separatorcolumn.f90->sourcefile~abstractcolumn.f90 sourcefile~abstractmeternode.f90 AbstractMeterNode.F90 sourcefile~separatorcolumn.f90->sourcefile~abstractmeternode.f90 sourcefile~simpletextcolumn.f90 SimpleTextColumn.F90 sourcefile~separatorcolumn.f90->sourcefile~simpletextcolumn.f90 sourcefile~abstractcolumn.f90->sourcefile~abstractmeternode.f90 sourcefile~distributedmeter.f90 DistributedMeter.F90 sourcefile~abstractcolumn.f90->sourcefile~distributedmeter.f90 sourcefile~abstractmeter.f90 AbstractMeter.F90 sourcefile~abstractmeternode.f90->sourcefile~abstractmeter.f90 sourcefile~simpletextcolumn.f90->sourcefile~abstractmeternode.f90 sourcefile~textcolumn.f90 TextColumn.F90 sourcefile~simpletextcolumn.f90->sourcefile~textcolumn.f90 sourcefile~mapl_errorhandling.f90 MAPL_ErrorHandling.F90 sourcefile~abstractmeter.f90->sourcefile~mapl_errorhandling.f90 sourcefile~distributedmeter.f90->sourcefile~abstractmeter.f90 sourcefile~abstractgauge.f90 AbstractGauge.F90 sourcefile~distributedmeter.f90->sourcefile~abstractgauge.f90 sourcefile~advancedmeter.f90 AdvancedMeter.F90 sourcefile~distributedmeter.f90->sourcefile~advancedmeter.f90 sourcefile~distributedmeter.f90->sourcefile~mapl_errorhandling.f90 sourcefile~textcolumn.f90->sourcefile~abstractmeternode.f90 sourcefile~abstractgauge.f90->sourcefile~abstractmeter.f90 sourcefile~advancedmeter.f90->sourcefile~abstractmeter.f90 sourcefile~advancedmeter.f90->sourcefile~abstractgauge.f90 sourcefile~mapl_throw.f90 MAPL_Throw.F90 sourcefile~mapl_errorhandling.f90->sourcefile~mapl_throw.f90

Files dependent on this one

sourcefile~~separatorcolumn.f90~~AfferentGraph sourcefile~separatorcolumn.f90 SeparatorColumn.F90 sourcefile~mapl_profiler.f90~2 MAPL_Profiler.F90 sourcefile~mapl_profiler.f90~2->sourcefile~separatorcolumn.f90 sourcefile~multicolumn.f90 MultiColumn.F90 sourcefile~mapl_profiler.f90~2->sourcefile~multicolumn.f90 sourcefile~profilereporter.f90 ProfileReporter.F90 sourcefile~mapl_profiler.f90~2->sourcefile~profilereporter.f90 sourcefile~multicolumn.f90->sourcefile~separatorcolumn.f90 sourcefile~profilereporter.f90->sourcefile~separatorcolumn.f90 sourcefile~profilereporter.f90->sourcefile~multicolumn.f90 sourcefile~abstractserver.f90 AbstractServer.F90 sourcefile~abstractserver.f90->sourcefile~mapl_profiler.f90~2 sourcefile~applicationsupport.f90 ApplicationSupport.F90 sourcefile~applicationsupport.f90->sourcefile~mapl_profiler.f90~2 sourcefile~demo.f90 demo.F90 sourcefile~demo.f90->sourcefile~mapl_profiler.f90~2 sourcefile~extdatadrivergridcomp.f90 ExtDataDriverGridComp.F90 sourcefile~extdatadrivergridcomp.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mapl.f90 MAPL.F90 sourcefile~mapl.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mapl_bundleio_test.f90 mapl_bundleio_test.F90 sourcefile~mapl_bundleio_test.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mapl_capgridcomp.f90 MAPL_CapGridComp.F90 sourcefile~mapl_capgridcomp.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mapl_generic.f90 MAPL_Generic.F90 sourcefile~mapl_generic.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mapl_nuopcwrappermod.f90 MAPL_NUOPCWrapperMod.F90 sourcefile~mapl_nuopcwrappermod.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mapl_verticalmethods.f90 MAPL_VerticalMethods.F90 sourcefile~mapl_verticalmethods.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mpi_demo.f90 mpi_demo.F90 sourcefile~mpi_demo.f90->sourcefile~mapl_profiler.f90~2 sourcefile~mpiserver.f90 MpiServer.F90 sourcefile~mpiserver.f90->sourcefile~mapl_profiler.f90~2 sourcefile~multigroupserver.f90 MultiGroupServer.F90 sourcefile~multigroupserver.f90->sourcefile~mapl_profiler.f90~2 sourcefile~regrid_util.f90 Regrid_Util.F90 sourcefile~regrid_util.f90->sourcefile~mapl_profiler.f90~2 sourcefile~serverthread.f90 ServerThread.F90 sourcefile~serverthread.f90->sourcefile~mapl_profiler.f90~2 sourcefile~test_advancedmeter.pf test_AdvancedMeter.pf sourcefile~test_advancedmeter.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_column.pf test_Column.pf sourcefile~test_column.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_distributedmeter.pf test_DistributedMeter.pf sourcefile~test_distributedmeter.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_exclusivecolumn.pf test_ExclusiveColumn.pf sourcefile~test_exclusivecolumn.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_meternode.pf test_MeterNode.pf sourcefile~test_meternode.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_meternodeiterator.pf test_MeterNodeIterator.pf sourcefile~test_meternodeiterator.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_namecolumn.pf test_NameColumn.pf sourcefile~test_namecolumn.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_percentagecolumn.pf test_PercentageColumn.pf sourcefile~test_percentagecolumn.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_profilereporter.pf test_ProfileReporter.pf sourcefile~test_profilereporter.pf->sourcefile~mapl_profiler.f90~2 sourcefile~test_timeprofiler.pf test_TimeProfiler.pf sourcefile~test_timeprofiler.pf->sourcefile~mapl_profiler.f90~2

Source Code

#include "unused_dummy.H"

module MAPL_SeparatorColumn
   use MAPL_AbstractColumn
   use MAPL_AbstractMeterNode
   use Mapl_SimpleTextColumn
   implicit none
   private

   public :: SeparatorColumn

   type, extends(SimpleTextColumn) :: SeparatorColumn
      private
      character(:), allocatable :: field
   contains
      procedure :: get_header
      procedure :: get_num_rows_header
      procedure :: get_row
   end type SeparatorColumn


   interface SeparatorColumn
      module procedure new_SeparatorColumn
   end interface SeparatorColumn


contains


   function new_SeparatorColumn(field) result(column)
      type (SeparatorColumn) :: column
      character(*), intent(in) :: field

      column%field = field
      call column%set_width(len(field))

   end function new_SeparatorColumn


   subroutine get_header(this, header)
      class (SeparatorColumn), intent(in) :: this
      character(:), allocatable, intent(out) :: header(:)

      header = [this%field]

   end subroutine get_header


   function get_row(this, node) result(row)
      character(:), allocatable :: row
      class (SeparatorColumn), intent(in) :: this
      class (AbstractMeterNode), intent(in) :: node

      integer :: n

      if (.false.) print*,shape(node) ! intentionally unused dummy

      n = this%get_width()
      
      allocate(character(n) :: row)
      row = this%field
      
   end function get_row


   integer function get_num_rows_header(this) result(num_rows)
      class(SeparatorColumn), intent(in) :: this
      _UNUSED_DUMMY(this)
      num_rows = 1
   end function get_num_rows_header
   
end module MAPL_SeparatorColumn