1 /*
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 
17 package com.android.systemui.statusbar.notification.stack
18 
19 import com.android.systemui.log.LogBuffer
20 import com.android.systemui.log.LogLevel
21 import com.android.systemui.log.dagger.NotificationSectionLog
22 import javax.inject.Inject
23 import javax.inject.Singleton
24 
25 private const val TAG = "NotifSections"
26 
27 @Singleton
28 class NotificationSectionsLogger @Inject constructor(
29     @NotificationSectionLog private val logBuffer: LogBuffer
30 ) {
31 
logStartSectionUpdatenull32     fun logStartSectionUpdate(reason: String) = logBuffer.log(
33             TAG,
34             LogLevel.DEBUG,
35             { str1 = reason },
<lambda>null36             { "Updating section boundaries: $reason" }
37     )
38 
logIncomingHeadernull39     fun logIncomingHeader(position: Int) = logPosition(position, "INCOMING HEADER")
40     fun logMediaControls(position: Int) = logPosition(position, "MEDIA CONTROLS")
41     fun logConversationsHeader(position: Int) = logPosition(position, "CONVERSATIONS HEADER")
42     fun logAlertingHeader(position: Int) = logPosition(position, "ALERTING HEADER")
43     fun logSilentHeader(position: Int) = logPosition(position, "SILENT HEADER")
44 
45     fun logOther(position: Int, clazz: Class<*>) = logBuffer.log(
46             TAG,
47             LogLevel.DEBUG,
48             {
49                 int1 = position
50                 str1 = clazz.name
51             },
<lambda>null52             { "$int1: other ($str1)" }
53     )
54 
logHeadsUpnull55     fun logHeadsUp(position: Int, isHeadsUp: Boolean) =
56             logPosition(position, "Heads Up", isHeadsUp)
57     fun logConversation(position: Int, isHeadsUp: Boolean) =
58             logPosition(position, "Conversation", isHeadsUp)
59     fun logAlerting(position: Int, isHeadsUp: Boolean) =
60             logPosition(position, "Alerting", isHeadsUp)
61     fun logSilent(position: Int, isHeadsUp: Boolean) =
62             logPosition(position, "Silent", isHeadsUp)
63     fun logForegroundService(position: Int, isHeadsUp: Boolean) =
64             logPosition(position, "Foreground Service", isHeadsUp)
65 
66     fun logStr(str: String) = logBuffer.log(TAG, LogLevel.DEBUG, { str1 = str }, { "$str1" })
67 
logPositionnull68     private fun logPosition(position: Int, label: String, isHeadsUp: Boolean) {
69         val headsUpTag = if (isHeadsUp) " (HUN)" else ""
70         logBuffer.log(
71                 TAG,
72                 LogLevel.DEBUG,
73                 {
74                     int1 = position
75                     str1 = label
76                     str2 = headsUpTag
77                 },
78                 {
79                     "$int1: $str1$str2"
80                 }
81         )
82     }
83 
logPositionnull84     private fun logPosition(position: Int, label: String) = logBuffer.log(
85             TAG,
86             LogLevel.DEBUG,
87             {
88                 int1 = position
89                 str1 = label
90             },
<lambda>null91             { "$int1: $str1" }
92     )
93 }
94