blob: c7fa50fe6fbc87d4931d0d42760364efa2051bba [file] [log] [blame]
/*
* Copyright (C) 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.tv.perf;
import android.app.Activity;
import android.app.Application;
/**
* Measures App startup.
*
* <p>This interface is lightweight to help measure both cold and warm startup latency.
* Implementations must not throw any Exception.
*
* <p>Because this class needs to be used in static initialization blocks, it can not be injected
* via dagger.
*
* <p>Creating implementations of this interface must be idempotent and lightweight. It does not
* need to be cached.
*/
public interface StartupMeasure {
/** To be be placed as the first static block in the app's Application class. */
void onAppClassLoaded();
/**
* To be placed in your {@link Application#onCreate} to let Performance Monitoring know when
* this happen.
*/
void onAppCreate(Application application);
/**
* To be placed in an initialization block of your {@link Activity} to let Performance
* Monitoring know when this activity is instantiated. Please note that this initialization
* block should be before other initialization blocks (if any) in your activity class.
*/
void onActivityInit();
}