Program Listing for File ecal_log.h

Return to documentation for file (ecal/core/include/ecal/ecal_log.h)

/* ========================= eCAL LICENSE =================================
 *
 * Copyright (C) 2016 - 2019 Continental Corporation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * ========================= eCAL LICENSE =================================
*/

#pragma once

#include <ecal/ecal_os.h>
#include <ecal/ecal_log_level.h>
#include <string>

namespace eCAL
{
  namespace Logging
  {
    ECAL_API void SetLogLevel(eCAL_Logging_eLogLevel level_);

    ECAL_API eCAL_Logging_eLogLevel GetLogLevel();

    ECAL_API void Log(const std::string& msg_);

    inline void Log(eCAL_Logging_eLogLevel level_, const std::string& msg_)
    {
      SetLogLevel(level_);
      Log(msg_);
    }

    ECAL_API void StartCoreTimer();

    ECAL_API void StopCoreTimer();

    ECAL_API void SetCoreTime(double time_);

    ECAL_API double GetCoreTime();
  }
}

#ifdef ECAL_C_DLL

#include <ecal/ecalc.h>

namespace eCAL
{
  namespace Logging
  {
    inline void SetLogLevel(eCAL_Logging_eLogLevel level_)
    {
      eCAL_Logging_SetLogLevel(level_);
    }

    inline eCAL_Logging_eLogLevel GetLogLevel()
    {
      return(eCAL_Logging_GetLogLevel());
    }

    inline void Log(const std::string& msg_)
    {
      eCAL_Logging_Log(msg_.c_str());
    }

    inline void StartCoreTimer()
    {
      eCAL_Logging_StartCoreTimer();
    }

    inline void StopCoreTimer()
    {
      eCAL_Logging_StopCoreTimer();
    }

    inline void SetCoreTime(double time_)
    {
      eCAL_Logging_SetCoreTime(time_);
    }

    inline double GetCoreTime()
    {
      return(eCAL_Logging_GetCoreTime());
    }
  }
}

#endif /* ECAL_C_DLL */