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

Side by Side Diff: talk/app/webrtc/java/src/org/webrtc/Logging.java

Issue 1335103004: Log to the webrtc log stream from webrtc/modules java code. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 5 years, 3 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 unified diff | Download patch
« no previous file with comments | « no previous file | talk/libjingle.gyp » ('j') | talk/libjingle.gyp » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 /*
2 * libjingle
3 * Copyright 2013 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 package org.webrtc;
29
30 import java.io.PrintWriter;
31 import java.io.StringWriter;
32 import java.nio.charset.Charset;
33 import java.util.EnumSet;
34
35 /** Java wrapper for WebRTC & libjingle logging. */
36 public class Logging {
37 static {
38 System.loadLibrary("jingle_peerconnection_so");
39 }
40
41 // Keep in sync with webrtc/common_types.h:TraceLevel.
42 public enum TraceLevel {
43 TRACE_NONE(0x0000),
44 TRACE_STATEINFO(0x0001),
45 TRACE_WARNING(0x0002),
46 TRACE_ERROR(0x0004),
47 TRACE_CRITICAL(0x0008),
48 TRACE_APICALL(0x0010),
49 TRACE_DEFAULT(0x00ff),
50 TRACE_MODULECALL(0x0020),
51 TRACE_MEMORY(0x0100),
52 TRACE_TIMER(0x0200),
53 TRACE_STREAM(0x0400),
54 TRACE_DEBUG(0x0800),
55 TRACE_INFO(0x1000),
56 TRACE_TERSEINFO(0x2000),
57 TRACE_ALL(0xffff);
58
59 public final int level;
60 TraceLevel(int level) {
61 this.level = level;
62 }
63 };
64
65 // Keep in sync with webrtc/base/logging.h:LoggingSeverity.
66 public enum Severity {
67 LS_SENSITIVE, LS_VERBOSE, LS_INFO, LS_WARNING, LS_ERROR,
68 };
69
70 public static void enableLogThreads() {
71 nativeEnableLogThreads();
72 }
73
74 public static void enableLogTimeStamps() {
75 nativeEnableLogTimeStamps();
76 }
77
78 // Enable tracing to |path| of messages of |levels| and |severity|.
79 // On Android, use "logcat:" for |path| to send output there.
80 public static void enableTracing(
81 String path, EnumSet<TraceLevel> levels, Severity severity) {
82 int nativeLevel = 0;
83 for (TraceLevel level : levels) {
84 nativeLevel |= level.level;
85 }
86 nativeEnableTracing(path, nativeLevel, severity.ordinal());
87 }
88
89 public static void log(Severity severity, String tag, String message) {
90 nativeLog(severity.ordinal(), tag, message);
91 }
92
93 public static void d(String tag, String message) {
94 log(Severity.LS_INFO, tag, message);
95 }
96
97 public static void e(String tag, String message) {
98 log(Severity.LS_ERROR, tag, message);
99 }
100
101 public static void w(String tag, String message) {
102 log(Severity.LS_WARNING, tag, message);
103 }
104
105 public static void e(String tag, String message, Throwable e) {
106 log(Severity.LS_ERROR, tag, message);
107 log(Severity.LS_ERROR, tag, e.toString());
108 log(Severity.LS_ERROR, tag, getStackTraceString(e));
109 }
110
111 public static void w(String tag, String message, Throwable e) {
112 log(Severity.LS_WARNING, tag, message);
113 log(Severity.LS_WARNING, tag, e.toString());
114 log(Severity.LS_WARNING, tag, getStackTraceString(e));
115 }
116
117 public static void v(String tag, String message) {
118 log(Severity.LS_VERBOSE, tag, message);
119 }
120
121 private static String getStackTraceString(Throwable e) {
122 if (e == null) {
123 return "";
124 }
125
126 StringWriter sw = new StringWriter();
127 PrintWriter pw = new PrintWriter(sw);
128 e.printStackTrace(pw);
129 return sw.toString();
130 }
131
132 private static native void nativeEnableTracing(
133 String path, int nativeLevels, int nativeSeverity);
134 private static native void nativeEnableLogThreads();
135 private static native void nativeEnableLogTimeStamps();
136 private static native void nativeLog(int severity, String tag, String message) ;
137 }
OLDNEW
« no previous file with comments | « no previous file | talk/libjingle.gyp » ('j') | talk/libjingle.gyp » ('J')

Powered by Google App Engine
This is Rietveld 408576698