You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
iceraven-browser/app/src/main/java/org/mozilla/fenix/perf/MarkersActivityLifecycleCal...

73 lines
2.6 KiB
Kotlin

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
package org.mozilla.fenix.perf
import android.app.Activity
import android.os.Bundle
import mozilla.components.concept.engine.Engine
import org.mozilla.fenix.HomeActivity
import org.mozilla.fenix.IntentReceiverActivity
import org.mozilla.fenix.android.DefaultActivityLifecycleCallbacks
/**
* Adds a profiler marker for each activity lifecycle callbacks. The callbacks are called by the
* super method (e.g. [Activity.onCreate] so the markers occur sometime during the execution of
* our implementation (e.g. [org.mozilla.fenix.HomeActivity.onCreate]) rather than at the beginning
* or end of that method.
*/
class MarkersActivityLifecycleCallbacks(
private val engine: Engine,
) : DefaultActivityLifecycleCallbacks {
private fun shouldSkip(): Boolean {
return engine.profiler?.isProfilerActive() != true
}
override fun onActivityCreated(activity: Activity, bundle: Bundle?) {
if (shouldSkip() ||
// These methods are manually instrumented with duration.
activity is HomeActivity ||
activity is IntentReceiverActivity
) {
return
}
engine.profiler?.addMarker(MARKER_NAME, "${activity::class.simpleName}.onCreate (via callbacks)")
}
override fun onActivityStarted(activity: Activity) {
if (shouldSkip() ||
// These methods are manually instrumented with duration.
activity is HomeActivity
) {
return
}
engine.profiler?.addMarker(MARKER_NAME, "${activity::class.simpleName}.onStart (via callbacks)")
}
override fun onActivityResumed(activity: Activity) {
if (shouldSkip()) { return }
engine.profiler?.addMarker(MARKER_NAME, "${activity::class.simpleName}.onResume (via callbacks)")
}
override fun onActivityPaused(activity: Activity) {
if (shouldSkip()) { return }
engine.profiler?.addMarker(MARKER_NAME, "${activity::class.simpleName}.onPause (via callbacks)")
}
override fun onActivityStopped(activity: Activity) {
if (shouldSkip()) { return }
engine.profiler?.addMarker(MARKER_NAME, "${activity::class.simpleName}.onStop (via callbacks)")
}
override fun onActivityDestroyed(activity: Activity) {
if (shouldSkip()) { return }
engine.profiler?.addMarker(MARKER_NAME, "${activity::class.simpleName}.onDestroy (via callbacks)")
}
companion object {
const val MARKER_NAME = "Activity Lifecycle"
}
}