|  | /* | 
|  | *  Copyright 2015 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. | 
|  | */ | 
|  |  | 
|  | #include "rtc_base/log_sinks.h" | 
|  |  | 
|  | #include <cstdio> | 
|  | #include <cstring> | 
|  | #include <string> | 
|  |  | 
|  | #include "absl/strings/string_view.h" | 
|  | #include "rtc_base/checks.h" | 
|  | #include "rtc_base/file_rotating_stream.h" | 
|  | #include "rtc_base/logging.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | FileRotatingLogSink::FileRotatingLogSink(absl::string_view log_dir_path, | 
|  | absl::string_view log_prefix, | 
|  | size_t max_log_size, | 
|  | size_t num_log_files) | 
|  | : FileRotatingLogSink(new FileRotatingStream(log_dir_path, | 
|  | log_prefix, | 
|  | max_log_size, | 
|  | num_log_files)) {} | 
|  |  | 
|  | FileRotatingLogSink::FileRotatingLogSink(FileRotatingStream* stream) | 
|  | : stream_(stream) { | 
|  | RTC_DCHECK(stream); | 
|  | } | 
|  |  | 
|  | FileRotatingLogSink::~FileRotatingLogSink() {} | 
|  |  | 
|  | void FileRotatingLogSink::OnLogMessage(const std::string& message) { | 
|  | OnLogMessage(absl::string_view(message)); | 
|  | } | 
|  |  | 
|  | void FileRotatingLogSink::OnLogMessage(absl::string_view message) { | 
|  | if (!stream_->IsOpen()) { | 
|  | std::fprintf(stderr, "Init() must be called before adding this sink.\n"); | 
|  | return; | 
|  | } | 
|  | stream_->Write(message.data(), message.size()); | 
|  | } | 
|  |  | 
|  | void FileRotatingLogSink::OnLogMessage(const std::string& message, | 
|  | LoggingSeverity sev, | 
|  | const char* tag) { | 
|  | OnLogMessage(absl::string_view(message), sev, tag); | 
|  | } | 
|  |  | 
|  | void FileRotatingLogSink::OnLogMessage(absl::string_view message, | 
|  | LoggingSeverity sev, | 
|  | const char* tag) { | 
|  | if (!stream_->IsOpen()) { | 
|  | std::fprintf(stderr, "Init() must be called before adding this sink.\n"); | 
|  | return; | 
|  | } | 
|  | stream_->Write(tag, strlen(tag)); | 
|  | stream_->Write(": ", 2); | 
|  | stream_->Write(message.data(), message.size()); | 
|  | } | 
|  |  | 
|  | bool FileRotatingLogSink::Init() { | 
|  | return stream_->Open(); | 
|  | } | 
|  |  | 
|  | bool FileRotatingLogSink::DisableBuffering() { | 
|  | return stream_->DisableBuffering(); | 
|  | } | 
|  |  | 
|  | CallSessionFileRotatingLogSink::CallSessionFileRotatingLogSink( | 
|  | absl::string_view log_dir_path, | 
|  | size_t max_total_log_size) | 
|  | : FileRotatingLogSink( | 
|  | new CallSessionFileRotatingStream(log_dir_path, max_total_log_size)) { | 
|  | } | 
|  |  | 
|  | CallSessionFileRotatingLogSink::~CallSessionFileRotatingLogSink() {} | 
|  |  | 
|  | }  // namespace webrtc |