mirror of
https://github.com/facebook/sapling.git
synced 2024-10-09 16:31:02 +03:00
49 lines
1.3 KiB
C++
49 lines
1.3 KiB
C++
|
/*
|
||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||
|
*
|
||
|
* This software may be used and distributed according to the terms of the
|
||
|
* GNU General Public License version 2.
|
||
|
*/
|
||
|
|
||
|
#include "eden/fs/telemetry/StructuredLoggerFactory.h"
|
||
|
#include <folly/logging/xlog.h>
|
||
|
#include "eden/fs/config/EdenConfig.h"
|
||
|
#include "eden/fs/telemetry/NullStructuredLogger.h"
|
||
|
|
||
|
#ifndef _WIN32
|
||
|
#include "eden/fs/telemetry/ScubaStructuredLogger.h"
|
||
|
#include "eden/fs/telemetry/SubprocessScribeLogger.h"
|
||
|
#endif
|
||
|
|
||
|
namespace facebook {
|
||
|
namespace eden {
|
||
|
|
||
|
std::unique_ptr<StructuredLogger> makeDefaultStructuredLogger(
|
||
|
const EdenConfig& config,
|
||
|
SessionInfo sessionInfo) {
|
||
|
const auto& binary = config.scribeLogger.getValue();
|
||
|
const auto& category = config.scribeCategory.getValue();
|
||
|
|
||
|
if (binary.empty()) {
|
||
|
return std::make_unique<NullStructuredLogger>();
|
||
|
}
|
||
|
|
||
|
if (category.empty()) {
|
||
|
XLOG(WARN)
|
||
|
<< "Scribe binary specified, but no category specified. Structured logging is disabled.";
|
||
|
return std::make_unique<NullStructuredLogger>();
|
||
|
}
|
||
|
|
||
|
#ifndef _WIN32
|
||
|
auto logger =
|
||
|
std::make_unique<SubprocessScribeLogger>(binary.c_str(), category);
|
||
|
return std::make_unique<ScubaStructuredLogger>(
|
||
|
std::move(logger), std::move(sessionInfo));
|
||
|
#else
|
||
|
return std::make_unique<NullStructuredLogger>();
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
} // namespace eden
|
||
|
} // namespace facebook
|