⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 class.cpp

📁 log4cxx 0.10 unix下编译包
💻 CPP
字号:
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */

#if defined(_MSC_VER)
#pragma warning ( disable: 4231 4251 4275 4786 )
#endif

#include <log4cxx/logstring.h>
#include <log4cxx/helpers/class.h>
#include <log4cxx/helpers/exception.h>
#include <log4cxx/helpers/object.h>
#include <map>
#include <log4cxx/helpers/stringhelper.h>
#include <log4cxx/log4cxx.h>
#if !defined(LOG4CXX)
#define LOG4CXX 1
#endif
#include <log4cxx/private/log4cxx_private.h>
#include <log4cxx/rollingfileappender.h>
#include <log4cxx/dailyrollingfileappender.h>


#include <log4cxx/asyncappender.h>
#include <log4cxx/consoleappender.h>
#include <log4cxx/fileappender.h>
#include <log4cxx/db/odbcappender.h>
#if defined(WIN32) || defined(_WIN32)
#if !defined(_WIN32_WCE)
#include <log4cxx/nt/nteventlogappender.h>
#endif
#include <log4cxx/nt/outputdebugstringappender.h>
#endif
#include <log4cxx/net/smtpappender.h>
#include <log4cxx/net/socketappender.h>
#include <log4cxx/net/sockethubappender.h>
#include <log4cxx/helpers/datagramsocket.h>
#include <log4cxx/net/syslogappender.h>
#include <log4cxx/net/telnetappender.h>
#include <log4cxx/writerappender.h>
#include <log4cxx/net/xmlsocketappender.h>
#include <log4cxx/layout.h>
#include <log4cxx/patternlayout.h>
#include <log4cxx/htmllayout.h>
#include <log4cxx/simplelayout.h>
#include <log4cxx/xml/xmllayout.h>
#include <log4cxx/ttcclayout.h>

#include <log4cxx/filter/levelmatchfilter.h>
#include <log4cxx/filter/levelrangefilter.h>
#include <log4cxx/filter/stringmatchfilter.h>
#include <log4cxx/rolling/filterbasedtriggeringpolicy.h>
#include <log4cxx/rolling/fixedwindowrollingpolicy.h>
#include <log4cxx/rolling/manualtriggeringpolicy.h>
#include <log4cxx/rolling/rollingfileappender.h>
#include <log4cxx/rolling/sizebasedtriggeringpolicy.h>
#include <log4cxx/rolling/timebasedrollingpolicy.h>

#include <log4cxx/xml/domconfigurator.h>
#include <log4cxx/propertyconfigurator.h>
#include <apr.h>


using namespace log4cxx;
using namespace log4cxx::helpers;
using namespace log4cxx::net;
using namespace log4cxx::filter;
using namespace log4cxx::xml;
using namespace log4cxx::rolling;

Class::Class() {
}

Class::~Class()
{
}

LogString Class::toString() const
{
        return getName();
}

ObjectPtr Class::newInstance() const
{
        throw InstantiationException(LOG4CXX_STR("Cannot create new instances of Class."));
#if LOG4CXX_RETURN_AFTER_THROW
        return 0;
#endif
}



Class::ClassMap& Class::getRegistry() {
    static ClassMap registry;
    return registry;
}

const Class& Class::forName(const LogString& className)
{
        LogString lowerName(StringHelper::toLowerCase(className));
        //
        //  check registry using full class name
        //
        const Class* clazz = getRegistry()[lowerName];
        if (clazz == 0) {
            LogString::size_type pos = className.find_last_of(LOG4CXX_STR(".$"));
            if (pos != LogString::npos) {
                LogString terminalName(lowerName, pos + 1, LogString::npos);
                clazz = getRegistry()[terminalName];
                if (clazz == 0) {
                    registerClasses();
                    clazz = getRegistry()[lowerName];
                    if (clazz == 0) {
                        clazz = getRegistry()[terminalName];
                    }
                }
            } else {
                registerClasses();
                clazz = getRegistry()[lowerName];
            }
        }
        if (clazz == 0) {
            throw ClassNotFoundException(className);
        }

        return *clazz;
}

bool Class::registerClass(const Class& newClass)
{
        getRegistry()[StringHelper::toLowerCase(newClass.getName())] = &newClass;
        return true;
}

void Class::registerClasses() {
#if APR_HAS_THREADS
        AsyncAppender::registerClass();
#endif        
        ConsoleAppender::registerClass();
        FileAppender::registerClass();
        log4cxx::db::ODBCAppender::registerClass();
#if (defined(WIN32) || defined(_WIN32))
#if !defined(_WIN32_WCE)
        log4cxx::nt::NTEventLogAppender::registerClass();
#endif
        log4cxx::nt::OutputDebugStringAppender::registerClass();
#endif
        log4cxx::RollingFileAppender::registerClass();
        SMTPAppender::registerClass();
        SocketAppender::registerClass();
#if APR_HAS_THREADS
        SocketHubAppender::registerClass();
#endif
        SyslogAppender::registerClass();
#if APR_HAS_THREADS
        TelnetAppender::registerClass();
#endif
        XMLSocketAppender::registerClass();
        DateLayout::registerClass();
        HTMLLayout::registerClass();
        PatternLayout::registerClass();
        SimpleLayout::registerClass();
        TTCCLayout::registerClass();
        XMLLayout::registerClass();
        LevelMatchFilter::registerClass();
        LevelRangeFilter::registerClass();
        StringMatchFilter::registerClass();
        log4cxx::RollingFileAppender::registerClass();
        log4cxx::rolling::RollingFileAppender::registerClass();
        DailyRollingFileAppender::registerClass();
        log4cxx::rolling::SizeBasedTriggeringPolicy::registerClass();
        log4cxx::rolling::TimeBasedRollingPolicy::registerClass();
        log4cxx::rolling::ManualTriggeringPolicy::registerClass();
        log4cxx::rolling::FixedWindowRollingPolicy::registerClass();
        log4cxx::rolling::FilterBasedTriggeringPolicy::registerClass();
        log4cxx::xml::DOMConfigurator::registerClass();
        log4cxx::PropertyConfigurator::registerClass();
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -