Xyst test code coverage report
Current view: top level - Main - Init.cpp (source / functions) Hit Total Coverage
Commit: b2278901c7a653f0d92b235cc98ed02988a87738 Lines: 52 59 88.1 %
Date: 2024-12-18 15:54:33 Functions: 6 6 100.0 %
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed Branches: 72 162 44.4 %

           Branch data     Line data    Source code
       1                 :            : // *****************************************************************************
       2                 :            : /*!
       3                 :            :   \file      src/Main/Init.cpp
       4                 :            :   \copyright 2012-2015 J. Bakosi,
       5                 :            :              2016-2018 Los Alamos National Security, LLC.,
       6                 :            :              2019-2021 Triad National Security, LLC.,
       7                 :            :              2022-2024 J. Bakosi
       8                 :            :              All rights reserved. See the LICENSE file for details.
       9                 :            :   \brief     Common initialization routines for main() functions for multiple
      10                 :            :      exectuables
      11                 :            :   \details   Common initialization routines for main() functions for multiple
      12                 :            :      exectuables. The functions in this file are used by multiple execitables
      13                 :            :      to ensure code-reuse and a uniform screen-output.
      14                 :            : */
      15                 :            : // *****************************************************************************
      16                 :            : 
      17                 :            : #include <ctime>
      18                 :            : #include <unistd.h>
      19                 :            : 
      20                 :            : #include "XystConfig.hpp"
      21                 :            : #include "Exception.hpp"
      22                 :            : #include "Init.hpp"
      23                 :            : 
      24                 :            : namespace tk {
      25                 :            : 
      26                 :        281 : static std::string workdir()
      27                 :            : // *****************************************************************************
      28                 :            : // Wrapper for POSIX API's getcwd() from unistd.h
      29                 :            : //! \return A stirng containing the current working directory
      30                 :            : // *****************************************************************************
      31                 :            : {
      32                 :            :   char cwd[1024];
      33                 :            : 
      34         [ +  - ]:        281 :   if ( getcwd(cwd, sizeof(cwd)) != nullptr )
      35         [ +  - ]:        281 :     return std::string( cwd );
      36                 :            :   else
      37 [ -  - ][ -  - ]:          0 :     Throw( "Error from POSIX API's getcwd()" );
                 [ -  - ]
      38                 :            : }
      39                 :            : 
      40                 :        281 : std::string curtime()
      41                 :            : // *****************************************************************************
      42                 :            : //  Wrapper for the standard C library's gettimeofday() from
      43                 :            : //! \return A stirng containing the current date and time
      44                 :            : // *****************************************************************************
      45                 :            : {
      46                 :            :   time_t current_time;
      47                 :            :   char* c_time_string;
      48                 :            : 
      49                 :            :   // Obtain current time as seconds elapsed since the Epoch
      50                 :        281 :   current_time = time( nullptr );
      51                 :            : 
      52         [ -  + ]:        281 :   if (current_time == static_cast<time_t>(-1))
      53 [ -  - ][ -  - ]:          0 :     Throw( "Failure to compute the current time" );
                 [ -  - ]
      54                 :            : 
      55                 :            :   // Convert to local time format
      56                 :        281 :   c_time_string = ctime(&current_time);
      57                 :            : 
      58         [ -  + ]:        281 :   if (c_time_string == nullptr)
      59 [ -  - ][ -  - ]:          0 :     Throw( "Failure to convert the current time" );
                 [ -  - ]
      60                 :            : 
      61                 :            :   // Convert to std::string and remove trailing newline
      62         [ +  - ]:        281 :   std::string str( c_time_string );
      63 [ +  - ][ +  - ]:        281 :   str.erase( std::remove(str.begin(), str.end(), '\n'), str.end() );
      64                 :            : 
      65                 :        562 :   return str;
      66                 :          0 : }
      67                 :            : 
      68                 :        281 : void echoHeader( HeaderType header )
      69                 :            : // *****************************************************************************
      70                 :            : //  Echo program header
      71                 :            : //! \param[in] header Header type enum indicating which header to print
      72                 :            : // *****************************************************************************
      73                 :            : {
      74                 :        281 :   tk::Print print;
      75         [ +  + ]:        281 :   if ( header == HeaderType::INCITER )
      76         [ +  - ]:        259 :     print.headerInciter();
      77         [ +  + ]:         22 :   else if ( header == HeaderType::UNITTEST )
      78         [ +  - ]:          2 :     print.headerUnitTest();
      79         [ +  - ]:         20 :   else if ( header == HeaderType::MESHCONV )
      80         [ +  - ]:         20 :     print.headerMeshConv();
      81                 :            :   else
      82 [ -  - ][ -  - ]:          0 :     Throw( "Header not available" );
                 [ -  - ]
      83                 :        281 : }
      84                 :            : 
      85                 :        281 : void echoBuildEnv( const std::string& executable )
      86                 :            : // *****************************************************************************
      87                 :            : //  Echo build environment
      88                 :            : //! \details Echo information read from build_dir/Base/Config.h filled by
      89                 :            : //!    CMake based on src/Main/Config.h.in.
      90                 :            : //! \param[in] executable Name of the executable
      91                 :            : // *****************************************************************************
      92                 :            : {
      93                 :        281 :   tk::Print print;
      94 [ +  - ][ +  - ]:        281 :   print.section( "Build environment" );
      95 [ +  - ][ +  - ]:        281 :   print.item( "Hostname", build_hostname() );
                 [ +  - ]
      96 [ +  - ][ +  - ]:        281 :   print.item( "Executable", executable );
      97 [ +  - ][ +  - ]:        281 :   if (!git_commit().empty()) print.item( "Git commit", git_commit() );
         [ +  - ][ +  - ]
                 [ +  - ]
      98 [ +  - ][ +  - ]:        281 :   print.item( "Build type", build_type() );
                 [ +  - ]
      99 [ +  - ][ +  - ]:        281 :   print.item( "C++ compiler", compiler() );
                 [ +  - ]
     100 [ +  - ][ +  - ]:        281 :   print.item( "Build date", build_date() );
                 [ +  - ]
     101                 :        281 : }
     102                 :            : 
     103                 :        281 : void echoRunEnv( int argc, char** argv, int quiescence )
     104                 :            : // *****************************************************************************
     105                 :            : //  Echo runtime environment
     106                 :            : //! \param[in] argc Number of command-line arguments to executable
     107                 :            : //! \param[in] argv C-style string array to command-line arguments to executable
     108                 :            : //! \param[in] quiescence True if quiescence detection is enabled
     109                 :            : // *****************************************************************************
     110                 :            : {
     111                 :        281 :   tk::Print print;
     112 [ +  - ][ +  - ]:        281 :   print.section( "Run-time environment" );
     113                 :            : 
     114 [ +  - ][ +  - ]:        281 :   print.item( "Date, time", curtime() );
                 [ +  - ]
     115 [ +  - ][ +  - ]:        281 :   print.item( "Work directory", workdir() );
                 [ +  - ]
     116 [ +  - ][ +  - ]:        281 :   print.item( "Executable (relative to work dir)", argv[0] );
     117                 :            : 
     118         [ +  - ]:        281 :   print << "Command line arguments: \'";
     119         [ +  + ]:        281 :   if (argc>1) {
     120 [ +  - ][ +  - ]:       1757 :     for (auto i=1; i<argc-1; ++i) print << argv[i] << ' ';
                 [ +  + ]
     121         [ +  - ]:        280 :     print << argv[argc-1];
     122                 :            :   }
     123         [ +  - ]:        281 :   print << "'\n";
     124                 :            : 
     125 [ +  - ][ +  - ]:        281 :   print.item( "Number of processing elements",
     126 [ +  - ][ +  - ]:        562 :               std::to_string( CkNumPes() ) + " (" +
     127 [ +  - ][ +  - ]:       1124 :               std::to_string( CkNumNodes() ) + 'x' +
     128         [ +  - ]:       1124 :               std::to_string( CkNumPes()/CkNumNodes() ) + ')' );
     129 [ +  + ][ +  - ]:        281 :   print.item( "Quiescence detection", quiescence ? "on" : "off" );
                 [ +  - ]
     130                 :        281 : }
     131                 :            : 
     132                 :            : // *****************************************************************************
     133                 :            : //  Finalize function for different executables
     134                 :            : //! \param[in] timer Vector of timers, held by the main chare
     135                 :            : //! \param[in,out] timestamp Vector of time stamps in h:m:s with labels
     136                 :            : //! \param[in] clean True if we should exit with a zero exit code, false to
     137                 :            : //!   exit with a nonzero exit code
     138                 :            : // *****************************************************************************
     139                 :        279 : void finalize( const std::vector< tk::Timer >& timer,
     140                 :            :                std::vector< std::pair< std::string,
     141                 :            :                                        tk::Timer::Watch > >& timestamp,
     142                 :            :                bool clean )
     143                 :            : {
     144                 :            :   try {
     145                 :            : 
     146         [ +  - ]:        279 :     if (!timer.empty()) {
     147 [ +  - ][ +  - ]:        279 :       timestamp.emplace_back( "Total runtime", timer[0].hms() );
     148 [ +  - ][ +  - ]:        279 :       tk::Print().time( "Timers (h:m:s)", timestamp );
     149                 :            :     }
     150                 :            : 
     151 [ +  - ][ -  - ]:        279 :     if (clean) CkExit(); else CkAbort("Failed");
     152                 :            : 
     153         [ -  - ]:          0 :   } catch (...) { tk::processExceptionCharm(); }
     154                 :          0 : }
     155                 :            : 
     156                 :            : } // tk::

Generated by: LCOV version 1.16