You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
243 lines
5.3 KiB
243 lines
5.3 KiB
// -*- C++ -*-
|
|
// Module: Log4CPLUS
|
|
// File: internal.h
|
|
// Created: 1/2009
|
|
// Author: Vaclav Haisman
|
|
//
|
|
//
|
|
// Copyright (C) 2009-2013, Vaclav Haisman. All rights reserved.
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without modifica-
|
|
// tion, are permitted provided that the following conditions are met:
|
|
//
|
|
// 1. Redistributions of source code must retain the above copyright notice,
|
|
// this list of conditions and the following disclaimer.
|
|
//
|
|
// 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
// this list of conditions and the following disclaimer in the documentation
|
|
// and/or other materials provided with the distribution.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
|
|
// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
// APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
|
|
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLU-
|
|
// DING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
// OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
// THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
/** @file
|
|
* This header contains declaration internal to log4cplus. They must never be
|
|
* visible from user accesible headers or exported in DLL/shared libray.
|
|
*/
|
|
|
|
|
|
#ifndef LOG4CPLUS_INTERNAL_INTERNAL_HEADER_
|
|
#define LOG4CPLUS_INTERNAL_INTERNAL_HEADER_
|
|
|
|
#include <log4cplus/config.hxx>
|
|
|
|
#if defined (LOG4CPLUS_HAVE_PRAGMA_ONCE)
|
|
#pragma once
|
|
#endif
|
|
|
|
#if ! defined (INSIDE_LOG4CPLUS)
|
|
# error "This header must not be be used outside log4cplus' implementation files."
|
|
#endif
|
|
|
|
#include <memory>
|
|
#include <vector>
|
|
#include <sstream>
|
|
#include <cstdio>
|
|
#include <log4cplus/tstring.h>
|
|
#include <log4cplus/streams.h>
|
|
#include <log4cplus/ndc.h>
|
|
#include <log4cplus/mdc.h>
|
|
#include <log4cplus/spi/loggingevent.h>
|
|
#include <log4cplus/thread/impl/tls.h>
|
|
#include <log4cplus/helpers/snprintf.h>
|
|
|
|
|
|
namespace log4cplus {
|
|
|
|
namespace internal {
|
|
|
|
|
|
//! Canonical empty string. It is used when the need to return empty string
|
|
//! by reference arises.
|
|
extern log4cplus::tstring const empty_str;
|
|
|
|
|
|
struct gft_scratch_pad
|
|
{
|
|
gft_scratch_pad ();
|
|
~gft_scratch_pad ();
|
|
|
|
void
|
|
reset ()
|
|
{
|
|
uc_q_str_valid = false;
|
|
q_str_valid = false;
|
|
s_str_valid = false;
|
|
ret.clear ();
|
|
}
|
|
|
|
log4cplus::tstring q_str;
|
|
log4cplus::tstring uc_q_str;
|
|
log4cplus::tstring s_str;
|
|
log4cplus::tstring ret;
|
|
log4cplus::tstring fmt;
|
|
log4cplus::tstring tmp;
|
|
std::vector<tchar> buffer;
|
|
bool uc_q_str_valid;
|
|
bool q_str_valid;
|
|
bool s_str_valid;
|
|
};
|
|
|
|
|
|
struct appender_sratch_pad
|
|
{
|
|
appender_sratch_pad ();
|
|
~appender_sratch_pad ();
|
|
|
|
tostringstream oss;
|
|
tstring str;
|
|
std::string chstr;
|
|
};
|
|
|
|
|
|
//! Per thread data.
|
|
struct per_thread_data
|
|
{
|
|
per_thread_data ();
|
|
~per_thread_data ();
|
|
|
|
tostringstream macros_oss;
|
|
tostringstream layout_oss;
|
|
DiagnosticContextStack ndc_dcs;
|
|
MappedDiagnosticContextMap mdc_map;
|
|
log4cplus::tstring thread_name;
|
|
log4cplus::tstring thread_name2;
|
|
gft_scratch_pad gft_sp;
|
|
appender_sratch_pad appender_sp;
|
|
log4cplus::tstring faa_str;
|
|
log4cplus::tstring ll_str;
|
|
spi::InternalLoggingEvent forced_log_ev;
|
|
std::FILE * fnull;
|
|
log4cplus::helpers::snprintf_buf snprintf_buf;
|
|
};
|
|
|
|
|
|
per_thread_data * alloc_ptd ();
|
|
|
|
// TLS key whose value is pointer struct per_thread_data.
|
|
extern log4cplus::thread::impl::tls_key_type tls_storage_key;
|
|
|
|
|
|
#if ! defined (LOG4CPLUS_SINGLE_THREADED) \
|
|
&& defined (LOG4CPLUS_THREAD_LOCAL_VAR)
|
|
|
|
extern LOG4CPLUS_THREAD_LOCAL_VAR per_thread_data * ptd;
|
|
|
|
|
|
inline
|
|
void
|
|
set_ptd (per_thread_data * p)
|
|
{
|
|
ptd = p;
|
|
}
|
|
|
|
|
|
inline
|
|
per_thread_data *
|
|
get_ptd (bool alloc = true)
|
|
{
|
|
if (LOG4CPLUS_UNLIKELY (! ptd && alloc))
|
|
return alloc_ptd ();
|
|
|
|
// The assert() does not belong here. get_ptd() might be called by
|
|
// cleanup code that can handle the returned NULL pointer.
|
|
//assert (ptd);
|
|
|
|
return ptd;
|
|
}
|
|
|
|
|
|
#else // defined (LOG4CPLUS_THREAD_LOCAL_VAR)
|
|
|
|
|
|
inline
|
|
void
|
|
set_ptd (per_thread_data * p)
|
|
{
|
|
thread::impl::tls_set_value (tls_storage_key, p);
|
|
}
|
|
|
|
|
|
inline
|
|
per_thread_data *
|
|
get_ptd (bool alloc = true)
|
|
{
|
|
per_thread_data * ptd
|
|
= reinterpret_cast<per_thread_data *>(
|
|
thread::impl::tls_get_value (tls_storage_key));
|
|
|
|
if (LOG4CPLUS_UNLIKELY (! ptd && alloc))
|
|
return alloc_ptd ();
|
|
|
|
return ptd;
|
|
}
|
|
|
|
|
|
#endif // defined (LOG4CPLUS_THREAD_LOCAL_VAR)
|
|
|
|
|
|
inline
|
|
tstring &
|
|
get_thread_name_str ()
|
|
{
|
|
return get_ptd ()->thread_name;
|
|
}
|
|
|
|
|
|
inline
|
|
tstring &
|
|
get_thread_name2_str ()
|
|
{
|
|
return get_ptd ()->thread_name2;
|
|
}
|
|
|
|
|
|
inline
|
|
gft_scratch_pad &
|
|
get_gft_scratch_pad ()
|
|
{
|
|
return get_ptd ()->gft_sp;
|
|
}
|
|
|
|
|
|
inline
|
|
appender_sratch_pad &
|
|
get_appender_sp ()
|
|
{
|
|
return get_ptd ()->appender_sp;
|
|
}
|
|
|
|
|
|
} // namespace internal {
|
|
|
|
|
|
namespace detail
|
|
{
|
|
|
|
LOG4CPLUS_EXPORT void clear_tostringstream (tostringstream &);
|
|
|
|
} // namespace detail
|
|
|
|
|
|
} // namespace log4cplus {
|
|
|
|
|
|
#endif // LOG4CPLUS_INTERNAL_INTERNAL_HEADER_
|