当前位置: 首页>>代码示例>>C++>>正文


C++ LogComponent类代码示例

本文整理汇总了C++中LogComponent的典型用法代码示例。如果您正苦于以下问题:C++ LogComponent类的具体用法?C++ LogComponent怎么用?C++ LogComponent使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了LogComponent类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: _getComponentForShortName

/*
 * Looks up a component by its short name, or returns kNumLogComponents
 * if the shortName is invalid
 */
const LogComponent _getComponentForShortName(StringData shortName) {
    for (int i = 0; i < int(LogComponent::kNumLogComponents); ++i) {
        LogComponent component = static_cast<LogComponent::Value>(i);
        if (component.getShortName() == shortName)
            return component;
    }
    return static_cast<LogComponent::Value>(LogComponent::kNumLogComponents);
}
开发者ID:AshishSanju,项目名称:mongo,代码行数:12,代码来源:parse_log_component_settings.cpp

示例2: TEST_F

 // Log names of all components should have the same length.
 TEST_F(LogTestUnadornedEncoder, LogComponentNameForLog) {
     size_t defaultNameForLogLength = componentDefault.getNameForLog().toString().length();
     ASSERT_NOT_EQUALS(0U, defaultNameForLogLength);
     for (int i = 0; i < int(LogComponent::kNumLogComponents); ++i) {
         LogComponent component = static_cast<LogComponent::Value>(i);
         ASSERT_EQUALS(defaultNameForLogLength, component.getNameForLog().toString().length());
     }
 }
开发者ID:Amosvista,项目名称:mongo,代码行数:9,代码来源:log_test.cpp

示例3: TEST_F

// Non-default log component short name should always be logged.
TEST_F(LogTestUnadornedEncoder, MessageEventDetailsEncoderLogComponent) {
    Date_t d = Date_t::now();
    const auto ctx = "WHAT"_sd;
    const auto msg = "HUH"_sd;
    for (int i = 0; i < int(LogComponent::kNumLogComponents); ++i) {
        LogComponent component = static_cast<LogComponent::Value>(i);
        testEncodedLogLine(MessageEventEphemeral(d, LogSeverity::Info(), component, ctx, msg),
                           str::stream() << " I " << component.getNameForLog() << " [");
    }
}
开发者ID:AshishSanju,项目名称:mongo,代码行数:11,代码来源:log_test.cpp

示例4: parseLogComponentSettings

StatusWith<std::vector<LogComponentSetting>> parseLogComponentSettings(const BSONObj& settings) {
    typedef std::vector<LogComponentSetting> Result;

    std::vector<LogComponentSetting> levelsToSet;
    std::vector<BSONObjIterator> iterators;

    LogComponent parentComponent = LogComponent::kDefault;
    BSONObjIterator iter(settings);

    while (iter.moreWithEOO()) {
        BSONElement elem = iter.next();
        if (elem.eoo()) {
            if (!iterators.empty()) {
                iter = iterators.back();
                iterators.pop_back();
                parentComponent = parentComponent.parent();
            }
            continue;
        }
        if (elem.fieldNameStringData() == "verbosity") {
            if (!elem.isNumber()) {
                return StatusWith<Result>(ErrorCodes::BadValue,
                                          str::stream() << "Expected "
                                                        << parentComponent.getDottedName()
                                                        << ".verbosity to be a number, but found "
                                                        << typeName(elem.type()));
            }
            levelsToSet.push_back((LogComponentSetting(parentComponent, elem.numberInt())));
            continue;
        }
        const StringData shortName = elem.fieldNameStringData();
        const LogComponent curr = _getComponentForShortName(shortName);

        if (curr == LogComponent::kNumLogComponents || curr.parent() != parentComponent) {
            return StatusWith<Result>(
                ErrorCodes::BadValue,
                str::stream() << "Invalid component name " << parentComponent.getDottedName() << "."
                              << shortName);
        }
        if (elem.isNumber()) {
            levelsToSet.push_back(LogComponentSetting(curr, elem.numberInt()));
            continue;
        }
        if (elem.type() != Object) {
            return StatusWith<Result>(ErrorCodes::BadValue,
                                      str::stream() << "Invalid type " << typeName(elem.type())
                                                    << "for component "
                                                    << parentComponent.getDottedName()
                                                    << "."
                                                    << shortName);
        }
        iterators.push_back(iter);
        parentComponent = curr;
        iter = BSONObjIterator(elem.Obj());
    }

    // Done walking settings
    return StatusWith<Result>(levelsToSet);
}
开发者ID:AshishSanju,项目名称:mongo,代码行数:59,代码来源:parse_log_component_settings.cpp

示例5: dassert

bool LogComponentSettings::shouldLog(LogComponent component, LogSeverity severity) const {
    dassert(int(component) >= 0 && int(component) < LogComponent::kNumLogComponents);

    // Should match parent component if minimum severity level is not configured for
    // component.
    dassert(_hasMinimumLoggedSeverity[component] ||
            _minimumLoggedSeverity[component] == _minimumLoggedSeverity[component.parent()]);

    return severity >= LogSeverity::cast(_minimumLoggedSeverity[component]);
}
开发者ID:Andiry,项目名称:mongo,代码行数:10,代码来源:log_component_settings.cpp

示例6: dassert

    void LogComponentSettings::clearMinimumLoggedSeverity(LogComponent component) {
        dassert(int(component) >= 0 && int(component) < LogComponent::kNumLogComponents);

        // LogComponent::kDefault must always be configured.
        if (component == LogComponent::kDefault) {
            setMinimumLoggedSeverity(component, LogSeverity::Log());
            return;
        }

        // Set unconfigured severity level to match LogComponent::kDefault.
        setMinimumLoggedSeverity(component, getMinimumLogSeverity(component.parent()));
        _hasMinimumLoggedSeverity[component] = false;
    }
开发者ID:3rf,项目名称:mongo,代码行数:13,代码来源:log_component_settings.cpp

示例7: log

        log() << "Logging A() -- " << A() << " -- done!" << std::endl;
        ASSERT_EQUALS(2U, _logLines.size());
        ASSERT_EQUALS(std::string("Golly!\n"), _logLines[0]);
        ASSERT_EQUALS(std::string("Logging A() -- Golly! -- done!\n"), _logLines[1]);
    }

    //
    // Instantiating this object is a basic test of static-initializer-time logging.
    //
    class B { 
    public:
        B() { log() << "Exercising initializer time logging."; }
    } b;

    // Constants for log component test cases.
    const LogComponent componentDefault = LogComponent::kDefault;
    const LogComponent componentA = LogComponent::kCommand;
    const LogComponent componentB = LogComponent::kAccessControl;
    const LogComponent componentC = LogComponent::kNetwork;
    const LogComponent componentD = LogComponent::kStorage;
    const LogComponent componentE = LogComponent::kJournal;

    // No log component declared at file scope.
    // Component severity configuration:
    //     LogComponent::kDefault: 2
    TEST_F(LogTestUnadornedEncoder, MongoLogMacroNoFileScopeLogComponent) {
        globalLogDomain()->setMinimumLoggedSeverity(LogSeverity::Debug(2));

        LOG(2) << "This is logged";
        LOG(3) << "This is not logged";
        ASSERT_EQUALS(1U, _logLines.size());
开发者ID:Amosvista,项目名称:mongo,代码行数:31,代码来源:log_test.cpp


注:本文中的LogComponent类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。