Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * libjingle | 2 * libjingle |
| 3 * Copyright 2015 Google Inc. | 3 * Copyright 2015 Google Inc. |
| 4 * | 4 * |
| 5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
| 6 * modification, are permitted provided that the following conditions are met: | 6 * modification, are permitted provided that the following conditions are met: |
| 7 * | 7 * |
| 8 * 1. Redistributions of source code must retain the above copyright notice, | 8 * 1. Redistributions of source code must retain the above copyright notice, |
| 9 * this list of conditions and the following disclaimer. | 9 * this list of conditions and the following disclaimer. |
| 10 * 2. Redistributions in binary form must reproduce the above copyright notice, | 10 * 2. Redistributions in binary form must reproduce the above copyright notice, |
| 11 * this list of conditions and the following disclaimer in the documentation | 11 * this list of conditions and the following disclaimer in the documentation |
| 12 * and/or other materials provided with the distribution. | 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 | 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. | 14 * derived from this software without specific prior written permission. |
| 15 * | 15 * |
| 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED | 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 | 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
| 18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO | 18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |
| 19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| 20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| 21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; | 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, | 22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |
| 23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR | 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 | 24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF |
| 25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 26 */ | 26 */ |
| 27 | 27 |
| 28 package org.webrtc; | 28 package org.webrtc; |
| 29 | 29 |
| 30 public class CallSessionFileRotatingLogSink { | 30 /** Java wrapper for a C++ RtpReceiverInterface. */ |
| 31 static { | 31 public class RtpReceiver { |
| 32 System.loadLibrary("jingle_peerconnection_so"); | 32 final long nativeRtpReceiver; |
| 33 | |
| 34 private MediaStreamTrack cachedTrack; | |
|
pthatcher1
2015/09/23 14:47:39
Why not just call it track?
| |
| 35 | |
| 36 public RtpReceiver(long nativeRtpReceiver) { | |
| 37 this.nativeRtpReceiver = nativeRtpReceiver; | |
| 38 long track = nativeTrack(nativeRtpReceiver); | |
| 39 cachedTrack = new MediaStreamTrack(track); | |
|
pthatcher1
2015/09/23 14:47:39
Please use the "this." prefix in both place or nei
| |
| 33 } | 40 } |
| 34 | 41 |
| 35 private long nativeSink; | 42 public MediaStreamTrack track() { |
| 36 | 43 return cachedTrack; |
| 37 public static byte[] getLogData(String dirPath) { | |
| 38 return nativeGetLogData(dirPath); | |
| 39 } | |
| 40 | |
| 41 public CallSessionFileRotatingLogSink( | |
| 42 String dirPath, int maxFileSize, Logging.Severity severity) { | |
| 43 nativeSink = nativeAddSink(dirPath, maxFileSize, severity.ordinal()); | |
| 44 } | 44 } |
| 45 | 45 |
| 46 public void dispose() { | 46 public void dispose() { |
| 47 if (nativeSink != 0) { | 47 free(nativeRtpReceiver); |
| 48 nativeDeleteSink(nativeSink); | 48 if (cachedTrack != null) { |
| 49 nativeSink = 0; | 49 cachedTrack.dispose(); |
| 50 } | 50 } |
| 51 } | 51 } |
| 52 | 52 |
| 53 private static native long nativeAddSink( | 53 // This should increment the reference count of the track, with the assumption |
| 54 String dirPath, int maxFileSize, int severity); | 54 // that a MediaStreamTrack will be created which will release it. |
| 55 private static native void nativeDeleteSink(long nativeSink); | 55 private static native long nativeTrack(long nativeRtpReceiver); |
| 56 private static native byte[] nativeGetLogData(String dirPath); | 56 |
| 57 } | 57 private static native void free(long nativeRtpReceiver); |
| 58 }; | |
| OLD | NEW |