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.deskclock.events 18 19 import android.content.Context 20 import androidx.annotation.StringRes 21 22 import com.android.deskclock.LogUtils 23 24 class LogEventTracker(val context: Context) : EventTracker { 25 sendEventnull26 override fun sendEvent( 27 @StringRes category: Int, 28 @StringRes action: Int, 29 @StringRes label: Int 30 ) { 31 if (label == 0) { 32 LOGGER.d("[%s] [%s]", safeGetString(category), safeGetString(action)) 33 } else { 34 LOGGER.d("[%s] [%s] [%s]", safeGetString(category), safeGetString(action), 35 safeGetString(label)) 36 } 37 } 38 39 /** 40 * @return Resource string represented by a given resource id, null if resId is invalid (0). 41 */ safeGetStringnull42 private fun safeGetString(@StringRes resId: Int): String? { 43 return if (resId == 0) null else context.getString(resId) 44 } 45 46 companion object { 47 private val LOGGER = LogUtils.Logger("Events") 48 } 49 } 50