ActivityLifeCycleMonitor.smali
.class public Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
.super Ljava/lang/Object;
.source "ActivityLifeCycleMonitor.java"
# static fields
.field private static volatile a:Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
# instance fields
.field private b:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map",
"<",
"Ljava/lang/String;",
"Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;",
">;"
}
.end annotation
.end field
.field private c:Landroid/content/Context;
.field private d:Ljava/lang/String;
# direct methods
.method private constructor <init>(Landroid/content/Context;Ljava/lang/String;)V
.registers 4
.prologue
.line 23
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 19
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
iput-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->b:Ljava/util/Map;
.line 24
iput-object p1, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->c:Landroid/content/Context;
.line 25
iput-object p2, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->d:Ljava/lang/String;
.line 26
return-void
.end method
.method private a(Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;)V
.registers 6
.prologue
.line 88
:try_start_0
new-instance v1, Lorg/json/JSONObject;
invoke-direct {v1}, Lorg/json/JSONObject;-><init>()V
.line 89
const-string v0, "1"
iget-object v2, p1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->pkgName:Ljava/lang/String;
invoke-virtual {v1, v0, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 90
const-string v0, "2"
iget-object v2, p1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->className:Ljava/lang/String;
invoke-virtual {v1, v0, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 91
const-string v0, "3"
iget-wide v2, p1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->startTime:J
invoke-static {v2, v3}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v0, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 92
const-string v0, "4"
iget-wide v2, p1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->endTime:J
invoke-static {v2, v3}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v0, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 94
iget-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->c:Landroid/content/Context;
invoke-static {v0}, Lcom/baidu/sofire/activitymonitor/LocalConfig;->getInstance(Landroid/content/Context;)Lcom/baidu/sofire/activitymonitor/LocalConfig;
move-result-object v0
invoke-virtual {v0}, Lcom/baidu/sofire/activitymonitor/LocalConfig;->getActivityReportData()Ljava/lang/String;
:try_end_32
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_32} :catch_59
move-result-object v2
.line 97
:try_start_33
new-instance v0, Lorg/json/JSONArray;
invoke-direct {v0, v2}, Lorg/json/JSONArray;-><init>(Ljava/lang/String;)V
:try_end_38
.catch Ljava/lang/Throwable; {:try_start_33 .. :try_end_38} :catch_52
.line 101
:goto_38
:try_start_38
invoke-virtual {v0, v1}, Lorg/json/JSONArray;->put(Ljava/lang/Object;)Lorg/json/JSONArray;
.line 102
invoke-virtual {v0}, Lorg/json/JSONArray;->length()I
move-result v1
const/16 v2, 0xa
if-lt v1, v2, :cond_5e
.line 103
invoke-direct {p0, v0}, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->a(Lorg/json/JSONArray;)V
.line 104
iget-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->c:Landroid/content/Context;
invoke-static {v0}, Lcom/baidu/sofire/activitymonitor/LocalConfig;->getInstance(Landroid/content/Context;)Lcom/baidu/sofire/activitymonitor/LocalConfig;
move-result-object v0
const-string v1, ""
invoke-virtual {v0, v1}, Lcom/baidu/sofire/activitymonitor/LocalConfig;->setActivityReportData(Ljava/lang/String;)V
.line 117
:goto_51
return-void
.line 98
:catch_52
move-exception v0
.line 99
new-instance v0, Lorg/json/JSONArray;
invoke-direct {v0}, Lorg/json/JSONArray;-><init>()V
:try_end_58
.catch Ljava/lang/Throwable; {:try_start_38 .. :try_end_58} :catch_59
goto :goto_38
.line 114
:catch_59
move-exception v0
.line 115
invoke-static {v0}, Lcom/baidu/sofire/activitymonitor/CommonUtil;->handleNuLException(Ljava/lang/Throwable;)V
goto :goto_51
.line 112
:cond_5e
:try_start_5e
iget-object v1, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->c:Landroid/content/Context;
invoke-static {v1}, Lcom/baidu/sofire/activitymonitor/LocalConfig;->getInstance(Landroid/content/Context;)Lcom/baidu/sofire/activitymonitor/LocalConfig;
move-result-object v1
invoke-virtual {v0}, Lorg/json/JSONArray;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Lcom/baidu/sofire/activitymonitor/LocalConfig;->setActivityReportData(Ljava/lang/String;)V
:try_end_6b
.catch Ljava/lang/Throwable; {:try_start_5e .. :try_end_6b} :catch_59
goto :goto_51
.end method
.method private a(Lorg/json/JSONArray;)V
.registers 8
.prologue
const/4 v0, 0x0
.line 121
:try_start_1
new-instance v1, Lorg/json/JSONObject;
invoke-direct {v1}, Lorg/json/JSONObject;-><init>()V
.line 122
invoke-virtual {p1}, Lorg/json/JSONArray;->length()I
move-result v2
.line 123
:goto_a
if-ge v0, v2, :cond_1a
.line 124
invoke-static {v0}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v3
invoke-virtual {p1, v0}, Lorg/json/JSONArray;->get(I)Ljava/lang/Object;
move-result-object v4
invoke-virtual {v1, v3, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 123
add-int/lit8 v0, v0, 0x1
goto :goto_a
.line 126
:cond_1a
new-instance v2, Lorg/json/JSONArray;
invoke-direct {v2}, Lorg/json/JSONArray;-><init>()V
.line 127
invoke-virtual {v2, v1}, Lorg/json/JSONArray;->put(Ljava/lang/Object;)Lorg/json/JSONArray;
.line 129
new-instance v1, Lorg/json/JSONObject;
invoke-direct {v1}, Lorg/json/JSONObject;-><init>()V
.line 130
new-instance v3, Lorg/json/JSONObject;
invoke-direct {v3}, Lorg/json/JSONObject;-><init>()V
.line 131
const-string v0, "0"
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v4
invoke-static {v4, v5}, Ljava/lang/Long;->toString(J)Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v0, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 132
const-string v4, "3"
iget-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->d:Ljava/lang/String;
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_71
const-string v0, ""
:goto_45
invoke-virtual {v3, v4, v0}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 133
const-string v0, "8"
const-string v4, "x0"
invoke-virtual {v3, v0, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 134
const-string v0, "9"
const/4 v4, 0x0
invoke-virtual {v3, v0, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;I)Lorg/json/JSONObject;
.line 135
const-string v0, "10"
const v4, 0xf46b9
invoke-virtual {v3, v0, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;I)Lorg/json/JSONObject;
.line 136
const-string v0, "Common_section"
invoke-virtual {v1, v0, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 137
const-string v0, "Module_section"
invoke-virtual {v1, v0, v2}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 138
invoke-virtual {v1}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
move-result-object v0
.line 139
iget-object v1, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->c:Landroid/content/Context;
invoke-static {v1, v0}, Lcom/baidu/sofire/activitymonitor/CommonUtil;->sendLog(Landroid/content/Context;Ljava/lang/String;)I
.line 143
:goto_70
return-void
.line 132
:cond_71
iget-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->d:Ljava/lang/String;
:try_end_73
.catch Ljava/lang/Throwable; {:try_start_1 .. :try_end_73} :catch_74
goto :goto_45
.line 140
:catch_74
move-exception v0
.line 141
invoke-static {v0}, Lcom/baidu/sofire/activitymonitor/CommonUtil;->handleNuLException(Ljava/lang/Throwable;)V
goto :goto_70
.end method
.method private a(Ljava/lang/String;)Z
.registers 4
.prologue
.line 76
:try_start_0
iget-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->b:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->keySet()Ljava/util/Set;
move-result-object v0
.line 77
if-eqz v0, :cond_17
invoke-interface {v0}, Ljava/util/Set;->size()I
move-result v1
if-lez v1, :cond_17
.line 78
invoke-interface {v0, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
:try_end_11
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_11} :catch_13
move-result v0
.line 83
:goto_12
return v0
.line 80
:catch_13
move-exception v0
.line 81
invoke-static {v0}, Lcom/baidu/sofire/activitymonitor/CommonUtil;->handleNuLException(Ljava/lang/Throwable;)V
.line 83
:cond_17
const/4 v0, 0x0
goto :goto_12
.end method
.method public static getInstance(Landroid/content/Context;Ljava/lang/String;)Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
.registers 4
.prologue
.line 29
sget-object v0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->a:Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
if-nez v0, :cond_13
.line 30
const-class v1, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
monitor-enter v1
.line 31
:try_start_7
sget-object v0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->a:Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
if-nez v0, :cond_12
.line 32
new-instance v0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
invoke-direct {v0, p0, p1}, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;-><init>(Landroid/content/Context;Ljava/lang/String;)V
sput-object v0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->a:Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
.line 34
:cond_12
monitor-exit v1
:try_end_13
.catchall {:try_start_7 .. :try_end_13} :catchall_16
.line 36
:cond_13
sget-object v0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->a:Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;
return-object v0
.line 34
:catchall_16
move-exception v0
:try_start_17
monitor-exit v1
:try_end_18
.catchall {:try_start_17 .. :try_end_18} :catchall_16
throw v0
.end method
# virtual methods
.method public onActivityPaused(Landroid/app/Activity;)V
.registers 6
.prologue
.line 59
:try_start_0
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Class;->getCanonicalName()Ljava/lang/String;
move-result-object v1
.line 60
iget-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->b:Ljava/util/Map;
invoke-interface {v0, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;
.line 61
if-eqz v0, :cond_20
.line 62
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
iput-wide v2, v0, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->endTime:J
.line 66
iget-object v2, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->b:Ljava/util/Map;
invoke-interface {v2, v1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 67
invoke-direct {p0, v0}, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->a(Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;)V
:try_end_20
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_20} :catch_21
.line 72
:cond_20
:goto_20
return-void
.line 69
:catch_21
move-exception v0
.line 70
invoke-static {v0}, Lcom/baidu/sofire/activitymonitor/CommonUtil;->handleNuLException(Ljava/lang/Throwable;)V
goto :goto_20
.end method
.method public onActivityResumed(Landroid/app/Activity;)V
.registers 6
.prologue
.line 41
:try_start_0
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Class;->getCanonicalName()Ljava/lang/String;
move-result-object v0
.line 42
new-instance v1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;
invoke-direct {v1}, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;-><init>()V
.line 43
invoke-virtual {p1}, Landroid/app/Activity;->getPackageName()Ljava/lang/String;
move-result-object v2
iput-object v2, v1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->pkgName:Ljava/lang/String;
.line 44
iput-object v0, v1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->className:Ljava/lang/String;
.line 45
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
iput-wide v2, v1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->startTime:J
.line 49
invoke-direct {p0, v0}, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->a(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_28
.line 50
iget-object v0, p0, Lcom/baidu/sofire/activitymonitor/ActivityLifeCycleMonitor;->b:Ljava/util/Map;
iget-object v2, v1, Lcom/baidu/sofire/activitymonitor/ActivityLaunchInfo;->className:Ljava/lang/String;
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_28
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_28} :catch_29
.line 55
:cond_28
:goto_28
return-void
.line 52
:catch_29
move-exception v0
.line 53
invoke-static {v0}, Lcom/baidu/sofire/activitymonitor/CommonUtil;->handleNuLException(Ljava/lang/Throwable;)V
goto :goto_28
.end method