mq5.1-source.src.share.cclient.util.Logger.hpp Maven / Gradle / Ivy
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 2000-2010 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
* or packager/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at packager/legal/LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
/*
* @(#)Logger.hpp 1.7 06/26/07
*/
#ifndef LOGGER_HPP
#define LOGGER_HPP
#include
#include
#include "../basictypes/Monitor.hpp"
#include "../cshim/mqcallback-types-priv.h"
// Notes:
// 1.) Finer logging correlates to a higher number
// 2.) The lowest level of actual logging is 0
// 3.) Error checking for valid file names is not done
// 4.) Accessor functions are not reentrant, mutators are
// 5.) There is only one lock for the entire class
typedef PRInt32 LogLevel;
// the iMQLoggingLevel enum depends on these values
const LogLevel NONE_LOG_LEVEL = -1;
const LogLevel SEVERE_LOG_LEVEL = 0;
const LogLevel WARNING_LOG_LEVEL = 1;
const LogLevel INFO_LOG_LEVEL = 2;
const LogLevel CONFIG_LOG_LEVEL = 3;
const LogLevel FINE_LOG_LEVEL = 4;
const LogLevel FINER_LOG_LEVEL = 5;
const LogLevel FINEST_LOG_LEVEL = 6;
// MIN_LOG_LEVEL refers to the lowest level where logging is ACTUALLY DONE!
const LogLevel MIN_LOG_LEVEL = SEVERE_LOG_LEVEL;
const LogLevel MAX_LOG_LEVEL = FINEST_LOG_LEVEL;
typedef PRInt32 LogCode;
/*
extern "C" {
typedef void (*LoggingCallback)(const LogLevel loggingLevel,
const LogCode logCode,
const char * logMessage,
const PRInt64 timeOfMessage, // value returned by PR_Now
const PRInt64 connectionID,
const char * filename,
const PRInt32 fileLineNumber,
// whatever was passed to setLoggingCallback
void * callbackData);
}
*/
// These should be class members, but MSVC 6.0 doesn't support it.
static const PRInt32 LOGGER_MAX_LOG_NAME_SIZE = 2000;
static const PRInt32 LOGGER_DEFAULT_MAXIMUM_LOG_SIZE = 1 * 1000 * 1000; // 1 MB
static const PRInt32 LOGGER_DEFAULT_MAXIMUM_LOG_INDEX = 9;
class Logger {
private:
static Logger * instance;
public:
static Logger * getInstance();
static void deleteInstance();
static void test(PRInt32 numLogThreads, const PRInt32 itemsToLog);
private:
LogLevel m_logFileLogLevel; // this is the normal file logLevel
LogLevel m_callbackLogLevel;
LogLevel m_stdErrLogLevel;
LogLevel g_logLevel; // the highest of above 3
MQLoggingFunc m_loggingCallback;
FILE * m_logFile;
Monitor m_monitor;
char m_logFileName[LOGGER_MAX_LOG_NAME_SIZE];
char * m_logFileName_gptr; // points passed last %g or NULL
// one mask for each logging level
PRUint32 m_mask[(MAX_LOG_LEVEL + 1)];
// passed to loggingCallback
void * m_callbackData;
// Maximum size of the log file in bytes
PRInt32 m_maximumLogSize;
// Log a message that looks something like
// SEVERE: 2001/12/11 16:18:20.0001 1131 foo.cpp:1000 0x0F203380 "Server is down"
void logva(const LogLevel logLevel,
const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
va_list argptr);
void parseLogFileName(char * logfilename, char ** gptr);
// Open the log file with the given log filename and location of %g.
// Slide all other logs down, deleting the oldest log.
void openLogFile(const char * const filename, const char * const gptr);
// Opens a new log file if this one is full
void openNewLogIfNecessary();
// The constructor is private because this is a Singleton
Logger();
void init();
void reset();
public:
~Logger();
LogLevel getLogLevel();
// sets the filename of the log file, if filename is NULL no
// information is logged to a file.
void setLogFileName(const char * const logfilename);
// sets/gets loggingCallback and callbackData
void setLoggingCallback(MQLoggingFunc const loggingCallback, void * callbackData);
MQLoggingFunc getLoggingCallback() const;
// sets/gets logLevel
void setLogFileLogLevel(const LogLevel logLevel);
LogLevel getLogFileLogLevel() const;
void setCallbackLogLevel(const LogLevel logLevel);
LogLevel getCallbackLogLevel() const;
void setStdErrLogLevel(const LogLevel logLevel);
LogLevel getStdErrLogLevel() const;
// sets/gets the logging mask for the specified level
void setMask(const LogLevel logLevel, const PRUint32 mask);
PRUint32 getMask(const LogLevel logLevel) const;
void setMaxLogSize(const PRInt32 maxLogSize);
PRInt32 getMaxLogSize() const;
PRInt32 getMaxLogIndex() const;
void log(const LogLevel logLevel,
const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
...);
void log_Severe(const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
...);
void log_Warning(const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
...);
void log_Info(const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
...);
void log_Config(const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
...);
void log_Fine(const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
...);
void log_Finer(const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format,
...);
void log_Finest(const char * const filename,
const PRInt32 lineNumber,
const PRUint32 mask,
const PRInt64 connectionID,
const LogCode logCode,
const char * const format, ...);
//
// Avoid all implicit shallow copies. Without these, the compiler
// will automatically define implementations for us.
//
private:
//
// These are not supported and are not implemented
//
Logger(const Logger& logger);
Logger& operator=(const Logger& logger);
};
#endif
© 2015 - 2025 Weber Informatics LLC | Privacy Policy