blob: 123cf78d74f8bd907215d45d807f0c9b09a85941 [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
Ned Burns7b813532020-04-10 19:08:06 -040064 /** Provides a logging buffer for all logs related to the data layer of notifications. */
65 @Provides
66 @Singleton
67 @NotifInteractionLog
68 public static LogBuffer provideNotifInteractionLogBuffer(
69 LogcatEchoTracker echoTracker,
70 DumpManager dumpManager) {
71 LogBuffer buffer = new LogBuffer("NotifInteractionLog", 50, 10, echoTracker);
72 buffer.attach(dumpManager);
73 return buffer;
74 }
75
Fabian Kozynskica30f572019-10-24 10:01:04 -040076 /** Provides a logging buffer for all logs related to Quick Settings. */
77 @Provides
78 @Singleton
79 @QSLog
80 public static LogBuffer provideQuickSettingsLogBuffer(
81 LogcatEchoTracker bufferFilter,
Ned Burnsc7cfa692020-02-12 21:38:50 -050082 DumpManager dumpManager) {
Fabian Kozynskica30f572019-10-24 10:01:04 -040083 LogBuffer buffer = new LogBuffer("QSLog", 500, 10, bufferFilter);
Ned Burnsc7cfa692020-02-12 21:38:50 -050084 buffer.attach(dumpManager);
Fabian Kozynskica30f572019-10-24 10:01:04 -040085 return buffer;
86 }
87
Ned Burns56a0ea12019-12-10 17:59:01 -050088 /** Allows logging buffers to be tweaked via adb on debug builds but not on prod builds. */
89 @Provides
90 @Singleton
91 public static LogcatEchoTracker provideLogcatEchoTracker(
92 ContentResolver contentResolver,
93 @Main Looper looper) {
94 if (Build.IS_DEBUGGABLE) {
95 return LogcatEchoTrackerDebug.create(contentResolver, looper);
96 } else {
97 return new LogcatEchoTrackerProd();
98 }
99 }
100}