Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 /* | |
| 2 * libjingle | |
| 3 * Copyright 2015 Google Inc. | |
| 4 * | |
| 5 * Redistribution and use in source and binary forms, with or without | |
| 6 * modification, are permitted provided that the following conditions are met: | |
| 7 * | |
| 8 * 1. Redistributions of source code must retain the above copyright notice, | |
| 9 * this list of conditions and the following disclaimer. | |
| 10 * 2. Redistributions in binary form must reproduce the above copyright notice, | |
| 11 * this list of conditions and the following disclaimer in the documentation | |
| 12 * and/or other materials provided with the distribution. | |
| 13 * 3. The name of the author may not be used to endorse or promote products | |
| 14 * derived from this software without specific prior written permission. | |
| 15 * | |
| 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED | |
| 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
| 18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO | |
| 19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |
| 20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | |
| 21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; | |
| 22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, | |
| 23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR | |
| 24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF | |
| 25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
| 26 */ | |
| 27 | |
| 28 #import "RTCFileLogger.h" | |
| 29 | |
| 30 #include "webrtc/base/checks.h" | |
| 31 #include "webrtc/base/logging.h" | |
| 32 #include "webrtc/base/scoped_ptr.h" | |
| 33 #include "webrtc/base/stream.h" | |
| 34 | |
| 35 NSString *const kDefaultLogFileName = @"webrtc.log"; | |
| 36 NSUInteger const kDefaultMaxFileSize = 10 * 1024 * 1024; // 10MB. | |
| 37 | |
| 38 namespace rtc { | |
| 39 | |
| 40 class StreamLogSink : public LogSink { | |
| 41 public: | |
| 42 // Creates a log sink that writes to the given stream. This log sink takes own ership of |stream|. | |
| 43 StreamLogSink(StreamInterface *stream) { | |
| 44 DCHECK(stream); | |
| 45 _stream.reset(stream); | |
| 46 } | |
| 47 | |
| 48 ~StreamLogSink() override {} | |
| 49 | |
| 50 void OnLogMessage(const std::string &message) override { | |
| 51 if (_stream) { | |
| 52 _stream->WriteAll(message.data(), message.size(), nullptr, nullptr); | |
| 53 } | |
| 54 } | |
| 55 | |
| 56 private: | |
| 57 scoped_ptr<StreamInterface> _stream; | |
| 58 }; | |
| 59 | |
| 60 } // namespace rtc | |
| 61 | |
| 62 @implementation RTCFileLogger { | |
| 63 NSString *_filePath; | |
| 64 NSUInteger _maxFileSize; | |
| 65 rtc::scoped_ptr<rtc::StreamLogSink> _logSink; | |
| 66 } | |
| 67 | |
| 68 - (instancetype)init { | |
| 69 NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUs erDomainMask, YES); | |
| 70 NSString *documentsDirPath = [paths firstObject]; | |
| 71 NSString *defaultFilePath = [documentsDirPath stringByAppendingPathComponent:k DefaultLogFileName]; | |
|
jiayl2
2015/07/06 18:18:14
Is this file private to the application? We should
tkchin
2015/07/06 20:36:49
Yes, it's private to the app bundle. Applications
| |
| 72 return [self initWithFilePath:defaultFilePath maxFileSize:kDefaultMaxFileSize] ; | |
| 73 } | |
| 74 | |
| 75 - (instancetype)initWithFilePath:(NSString *)filePath maxFileSize:(NSUInteger)ma xFileSize { | |
| 76 NSParameterAssert(filePath.length); | |
| 77 NSParameterAssert(maxFileSize); | |
| 78 if (self = [super init]) { | |
| 79 _filePath = filePath; | |
| 80 _maxFileSize = maxFileSize; | |
| 81 } | |
| 82 return self; | |
| 83 } | |
| 84 | |
| 85 - (void)dealloc { | |
| 86 [self stop]; | |
| 87 } | |
| 88 | |
| 89 - (void)start { | |
| 90 if (_logSink) { | |
| 91 return; | |
| 92 } | |
| 93 rtc::scoped_ptr<rtc::CircularFileStream> stream; | |
| 94 stream.reset(new rtc::CircularFileStream(kDefaultMaxFileSize)); | |
| 95 if (!stream->Open([_filePath UTF8String], "wb", nullptr)) { | |
| 96 LOG(LS_ERROR) << "Failed to open log file at path: " << [_filePath UTF8Strin g]; | |
| 97 return; | |
| 98 } | |
| 99 _logSink.reset(new rtc::StreamLogSink(stream.release())); | |
| 100 | |
| 101 rtc::LogMessage::LogThreads(true); | |
| 102 rtc::LogMessage::LogTimestamps(true); | |
| 103 rtc::LogMessage::AddLogToStream(_logSink.get(), rtc::LS_INFO); | |
|
jiayl2
2015/07/06 18:18:14
FYI we'll need a switch to turn on verbose logging
tkchin
2015/07/06 20:36:50
What logs do we get in verbose?
jiayl2
2015/07/06 20:57:56
Verbose webrtc logs contain detailed information a
tkchin_webrtc
2015/07/07 23:30:10
Ok. Making that the default then if it contains us
jiayl2
2015/07/08 16:32:12
We should default to "info". Verbose is too noisy
tkchin_webrtc
2015/07/08 18:18:23
Done.
| |
| 104 } | |
| 105 | |
| 106 - (void)stop { | |
| 107 if (!_logSink) { | |
| 108 return; | |
| 109 } | |
| 110 rtc::LogMessage::RemoveLogToStream(_logSink.get()); | |
| 111 _logSink.reset(); | |
| 112 } | |
| 113 | |
| 114 - (NSString *)log { | |
| 115 return [[self class] contentsOfFileAtPath:_filePath]; | |
| 116 } | |
| 117 | |
| 118 #pragma mark - Private | |
| 119 | |
| 120 + (NSString *)contentsOfFileAtPath:(NSString *)path { | |
| 121 NSError *error = nil; | |
| 122 NSString *contents = | |
| 123 [NSString stringWithContentsOfFile:path encoding:NSUTF8StringEncoding erro r:&error]; | |
| 124 if (error) { | |
| 125 LOG(LS_ERROR) << "Failed to read contents of file at path: " << [path UTF8St ring] | |
| 126 << " Error: " << [error.localizedDescription UTF8String]; | |
| 127 return nil; | |
| 128 } | |
| 129 return contents; | |
| 130 } | |
| 131 | |
| 132 @end | |
| OLD | NEW |