/* * Copyright 2019 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef TEST_LOGGING_LOG_WRITER_H_ #define TEST_LOGGING_LOG_WRITER_H_ #include #include #include #include #include "api/rtc_event_log_output.h" #include "rtc_base/strings/string_builder.h" namespace webrtc { template inline void LogWriteFormat(RtcEventLogOutput* out_, const char* fmt, ...) { va_list args, copy; va_start(args, fmt); va_copy(copy, args); const int predicted_length = std::vsnprintf(nullptr, 0, fmt, copy); va_end(copy); RTC_DCHECK_GE(predicted_length, 0); std::string out_str(predicted_length, '\0'); if (predicted_length > 0) { // Pass "+ 1" to vsnprintf to include space for the '\0'. const int actual_length = std::vsnprintf(&out_str.front(), predicted_length + 1, fmt, args); RTC_DCHECK_GE(actual_length, 0); } va_end(args); out_->Write(out_str); } class LogWriterFactoryInterface { public: virtual std::unique_ptr Create(std::string filename) = 0; virtual ~LogWriterFactoryInterface() = default; }; class LogWriterFactoryAddPrefix : public LogWriterFactoryInterface { public: LogWriterFactoryAddPrefix(LogWriterFactoryInterface* base, std::string prefix); std::unique_ptr Create(std::string filename) override; private: LogWriterFactoryInterface* const base_factory_; const std::string prefix_; }; } // namespace webrtc #endif // TEST_LOGGING_LOG_WRITER_H_