1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-04 05:17:40 +03:00
one/include/NebulaLog.h

101 lines
3.1 KiB
C++

/* -------------------------------------------------------------------------- */
/* Copyright 2002-2010, OpenNebula Project Leads (OpenNebula.org) */
/* */
/* 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. */
/* -------------------------------------------------------------------------- */
#ifndef _NEBULA_LOG_H_
#define _NEBULA_LOG_H_
#include "Log.h"
#include <sstream>
using namespace std;
/**
* The Logger class for the OpenNebula components
*/
class NebulaLog
{
public:
enum LogType {
FILE = 0,
FILE_TS = 1,
CERR = 2
};
// ---------------------------------------------------------------
// Logging
// ---------------------------------------------------------------
static void init_log_system(
LogType ltype,
Log::MessageType clevel,
const char * filename = 0,
ios_base::openmode mode = ios_base::trunc)
{
switch(ltype)
{
case FILE:
NebulaLog::logger = new FileLog(filename,clevel,mode);
break;
case FILE_TS:
NebulaLog::logger = new FileLogTS(filename,clevel,mode);
break;
default:
NebulaLog::logger = new CerrLog(clevel);
break;
}
};
static void finalize_log_system()
{
delete logger;
}
static void log(
const char * module,
const Log::MessageType type,
const char * message)
{
logger->log(module,type,message);
};
static void log(
const char * module,
const Log::MessageType type,
const ostringstream& message)
{
logger->log(module,type,message.str().c_str());
};
static void log(
const char * module,
const Log::MessageType type,
const string& message)
{
logger->log(module,type,message.c_str());
};
private:
NebulaLog(){};
~NebulaLog(){};
static Log * logger;
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
#endif /* _NEBULA_LOG_H_ */