blob: 9c89fee5cba11a51e61efbefc4886b35331bee10 [file] [log] [blame]
Ned Burns56a0ea12019-12-10 17:59:01 -05001/*
2 * Copyright (C) 2020 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package com.android.systemui.log.dagger;
18
19import android.content.ContentResolver;
20import android.os.Build;
21import android.os.Looper;
22
Ned Burns56a0ea12019-12-10 17:59:01 -050023import com.android.systemui.dagger.qualifiers.Main;
Ned Burnsc7cfa692020-02-12 21:38:50 -050024import com.android.systemui.dump.DumpManager;
Ned Burns56a0ea12019-12-10 17:59:01 -050025import com.android.systemui.log.LogBuffer;
26import com.android.systemui.log.LogcatEchoTracker;
27import com.android.systemui.log.LogcatEchoTrackerDebug;
28import com.android.systemui.log.LogcatEchoTrackerProd;
29
30import javax.inject.Singleton;
31
32import dagger.Module;
33import dagger.Provides;
34
35/**
36 * Dagger module for providing instances of {@link LogBuffer}.
37 */
38@Module
39public class LogModule {
40 /** Provides a logging buffer for doze-related logs. */
41 @Provides
42 @Singleton
43 @DozeLog
44 public static LogBuffer provideDozeLogBuffer(
Ned Burns30d67702020-01-28 12:58:45 -050045 LogcatEchoTracker bufferFilter,
Ned Burnsc7cfa692020-02-12 21:38:50 -050046 DumpManager dumpManager) {
Ned Burns56a0ea12019-12-10 17:59:01 -050047 LogBuffer buffer = new LogBuffer("DozeLog", 100, 10, bufferFilter);
Ned Burnsc7cfa692020-02-12 21:38:50 -050048 buffer.attach(dumpManager);
Ned Burns56a0ea12019-12-10 17:59:01 -050049 return buffer;
50 }
51
52 /** Provides a logging buffer for all logs related to the data layer of notifications. */
53 @Provides
54 @Singleton
55 @NotificationLog
56 public static LogBuffer provideNotificationsLogBuffer(
57 LogcatEchoTracker bufferFilter,
Ned Burnsc7cfa692020-02-12 21:38:50 -050058 DumpManager dumpManager) {
Ned Burnsaaeb44b2020-02-12 23:48:26 -050059 LogBuffer buffer = new LogBuffer("NotifLog", 1000, 10, bufferFilter);
Ned Burnsc7cfa692020-02-12 21:38:50 -050060 buffer.attach(dumpManager);
Ned Burns56a0ea12019-12-10 17:59:01 -050061 return buffer;
62 }
63
Steve Elliott1ba1b7c2020-05-05 14:16:32 -040064 /** Provides a logging buffer for all logs related to managing notification sections. */
65 @Provides
66 @Singleton
67 @NotificationSectionLog
68 public static LogBuffer provideNotificationSectionLogBuffer(
69 LogcatEchoTracker bufferFilter,
70 DumpManager dumpManager) {
71 LogBuffer buffer = new LogBuffer("NotifSectionLog", 500, 10, bufferFilter);
72 buffer.attach(dumpManager);
73 return buffer;
74 }
75
Ned Burns7b813532020-04-10 19:08:06 -040076 /** Provides a logging buffer for all logs related to the data layer of notifications. */
77 @Provides
78 @Singleton
79 @NotifInteractionLog
80 public static LogBuffer provideNotifInteractionLogBuffer(
81 LogcatEchoTracker echoTracker,
82 DumpManager dumpManager) {
83 LogBuffer buffer = new LogBuffer("NotifInteractionLog", 50, 10, echoTracker);
84 buffer.attach(dumpManager);
85 return buffer;
86 }
87
Fabian Kozynskica30f572019-10-24 10:01:04 -040088 /** Provides a logging buffer for all logs related to Quick Settings. */
89 @Provides
90 @Singleton
91 @QSLog
92 public static LogBuffer provideQuickSettingsLogBuffer(
93 LogcatEchoTracker bufferFilter,
Ned Burnsc7cfa692020-02-12 21:38:50 -050094 DumpManager dumpManager) {
Fabian Kozynskica30f572019-10-24 10:01:04 -040095 LogBuffer buffer = new LogBuffer("QSLog", 500, 10, bufferFilter);
Ned Burnsc7cfa692020-02-12 21:38:50 -050096 buffer.attach(dumpManager);
Fabian Kozynskica30f572019-10-24 10:01:04 -040097 return buffer;
98 }
99
Ned Burns56a0ea12019-12-10 17:59:01 -0500100 /** Allows logging buffers to be tweaked via adb on debug builds but not on prod builds. */
101 @Provides
102 @Singleton
103 public static LogcatEchoTracker provideLogcatEchoTracker(
104 ContentResolver contentResolver,
105 @Main Looper looper) {
106 if (Build.IS_DEBUGGABLE) {
107 return LogcatEchoTrackerDebug.create(contentResolver, looper);
108 } else {
109 return new LogcatEchoTrackerProd();
110 }
111 }
112}