LCOV - code coverage report
Current view: top level - EnergyPlus - EnergyPlusLogger.cc (source / functions) Coverage Total Hit
Test: lcov.output.filtered Lines: 7.4 % 27 2
Test Date: 2025-05-22 16:09:37 Functions: 20.0 % 5 1

            Line data    Source code
       1              : // EnergyPlus, Copyright (c) 1996-2025, The Board of Trustees of the University of Illinois,
       2              : // The Regents of the University of California, through Lawrence Berkeley National Laboratory
       3              : // (subject to receipt of any required approvals from the U.S. Dept. of Energy), Oak Ridge
       4              : // National Laboratory, managed by UT-Battelle, Alliance for Sustainable Energy, LLC, and other
       5              : // contributors. All rights reserved.
       6              : //
       7              : // NOTICE: This Software was developed under funding from the U.S. Department of Energy and the
       8              : // U.S. Government consequently retains certain rights. As such, the U.S. Government has been
       9              : // granted for itself and others acting on its behalf a paid-up, nonexclusive, irrevocable,
      10              : // worldwide license in the Software to reproduce, distribute copies to the public, prepare
      11              : // derivative works, and perform publicly and display publicly, and to permit others to do so.
      12              : //
      13              : // Redistribution and use in source and binary forms, with or without modification, are permitted
      14              : // provided that the following conditions are met:
      15              : //
      16              : // (1) Redistributions of source code must retain the above copyright notice, this list of
      17              : //     conditions and the following disclaimer.
      18              : //
      19              : // (2) Redistributions in binary form must reproduce the above copyright notice, this list of
      20              : //     conditions and the following disclaimer in the documentation and/or other materials
      21              : //     provided with the distribution.
      22              : //
      23              : // (3) Neither the name of the University of California, Lawrence Berkeley National Laboratory,
      24              : //     the University of Illinois, U.S. Dept. of Energy nor the names of its contributors may be
      25              : //     used to endorse or promote products derived from this software without specific prior
      26              : //     written permission.
      27              : //
      28              : // (4) Use of EnergyPlus(TM) Name. If Licensee (i) distributes the software in stand-alone form
      29              : //     without changes from the version obtained under this License, or (ii) Licensee makes a
      30              : //     reference solely to the software portion of its product, Licensee must refer to the
      31              : //     software as "EnergyPlus version X" software, where "X" is the version number Licensee
      32              : //     obtained under this License and may not use a different name for the software. Except as
      33              : //     specifically required in this Section (4), Licensee shall not use in a company name, a
      34              : //     product name, in advertising, publicity, or other promotional activities any name, trade
      35              : //     name, trademark, logo, or other designation of "EnergyPlus", "E+", "e+" or confusingly
      36              : //     similar designation, without the U.S. Department of Energy's prior written consent.
      37              : //
      38              : // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
      39              : // IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
      40              : // AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
      41              : // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
      42              : // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
      43              : // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
      44              : // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
      45              : // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
      46              : // POSSIBILITY OF SUCH DAMAGE.
      47              : 
      48              : #include <EnergyPlus/EnergyPlusLogger.hh>
      49              : #include <EnergyPlus/UtilityRoutines.hh>
      50              : 
      51              : using namespace EnergyPlus;
      52              : 
      53         4285 : EnergyPlusLogger::EnergyPlusLogger(Log_level minimum_level_to_log) : Courierr::Courierr(), minimum_level(minimum_level_to_log)
      54              : {
      55         4285 : }
      56              : 
      57            0 : void EnergyPlusLogger::error(const std::string_view message)
      58              : {
      59            0 :     if (Log_level::Error >= minimum_level) {
      60            0 :         const std::pair<EnergyPlusData *, std::string> &contextPair =
      61              :             *(reinterpret_cast<std::pair<EnergyPlusData *, std::string> *>(message_context));
      62            0 :         std::string fullMessage = fmt::format("{}: {}", contextPair.second, message);
      63            0 :         ShowSevereError(*contextPair.first, fullMessage);
      64            0 :     }
      65            0 : }
      66              : 
      67            0 : void EnergyPlusLogger::warning(const std::string_view message)
      68              : {
      69            0 :     if (Log_level::Warning >= minimum_level) {
      70            0 :         const std::pair<EnergyPlusData *, std::string> &contextPair =
      71              :             *(reinterpret_cast<std::pair<EnergyPlusData *, std::string> *>(message_context));
      72            0 :         std::string fullMessage = fmt::format("{}: {}", contextPair.second, message);
      73            0 :         ShowWarningError(*contextPair.first, fullMessage);
      74            0 :     }
      75            0 : }
      76              : 
      77            0 : void EnergyPlusLogger::info(const std::string_view message)
      78              : {
      79            0 :     if (Log_level::Info >= minimum_level) {
      80            0 :         const std::pair<EnergyPlusData *, std::string> &contextPair =
      81              :             *(reinterpret_cast<std::pair<EnergyPlusData *, std::string> *>(message_context));
      82            0 :         std::string fullMessage = fmt::format("{}: {}", contextPair.second, message);
      83            0 :         ShowMessage(*contextPair.first, fullMessage);
      84            0 :     }
      85            0 : }
      86              : 
      87            0 : void EnergyPlusLogger::debug(const std::string_view message)
      88              : {
      89            0 :     if (Log_level::Debug >= minimum_level) {
      90            0 :         info(message);
      91              :     }
      92            0 : }
        

Generated by: LCOV version 2.0-1