Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(570)

Unified Diff: webrtc/base/logsinks.h

Issue 1230823009: Add rotating log file stream. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Cleanup Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webrtc/base/logsinks.h
diff --git a/webrtc/base/logsinks.h b/webrtc/base/logsinks.h
new file mode 100644
index 0000000000000000000000000000000000000000..ddb68e3715fddf0d6d6e60775071fc7b7d5087bc
--- /dev/null
+++ b/webrtc/base/logsinks.h
@@ -0,0 +1,67 @@
+/*
+ * 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.
+ */
+
+#ifndef WEBRTC_BASE_FILE_ROTATING_LOG_SINK_H_
+#define WEBRTC_BASE_FILE_ROTATING_LOG_SINK_H_
+
+#include <string>
+
+#include "webrtc/base/constructormagic.h"
+#include "webrtc/base/logging.h"
+#include "webrtc/base/scoped_ptr.h"
+#include "webrtc/base/stream.h"
+
+namespace rtc {
+
+// Log sink that uses a FileRotatingStream to write to disk.
+// Init() must be called before adding this sink.
+class FileRotatingLogSink : public LogSink {
+ public:
+ // |num_log_files| must be greater than 1 and |max_log_size| must be greater
+ // than 0.
+ FileRotatingLogSink(const std::string& log_dir_path,
+ const std::string& log_prefix,
+ size_t max_log_size,
+ size_t num_log_files);
+ ~FileRotatingLogSink() override;
+
+ // Writes the message to the current file. It will spill over to the next
+ // file if needed.
+ void OnLogMessage(const std::string& message) override;
+
+ // Deletes any existing files in the directory and creates a new log file.
+ virtual bool Init();
+
+ protected:
+ explicit FileRotatingLogSink(FileRotatingStream* stream);
+
+ private:
+ scoped_ptr<FileRotatingStream> stream_;
+
+ DISALLOW_COPY_AND_ASSIGN(FileRotatingLogSink);
+};
+
+// Log sink that uses a MobileDeviceLogSink to write to disk.
jiayl2 2015/07/20 23:27:05 nit: uses a MobileDeviceLogStream ...
tkchin_webrtc 2015/07/21 20:39:12 Done.
+// Init() must be called before adding this sink.
+class MobileDeviceLogSink : public FileRotatingLogSink {
+ public:
+ MobileDeviceLogSink(const std::string& log_dir_path,
+ size_t max_total_log_size);
+ ~MobileDeviceLogSink() override;
+
+ private:
+ scoped_ptr<MobileDeviceLogStream> stream_;
+
+ DISALLOW_COPY_AND_ASSIGN(MobileDeviceLogSink);
+};
+
+} // namespace rtc
+
+#endif // WEBRTC_BASE_FILE_ROTATING_LOG_SINK_H_
« no previous file with comments | « webrtc/base/base.gyp ('k') | webrtc/base/logsinks.cc » ('j') | webrtc/base/stream.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698