u.smali
.class public Lcom/umeng/analytics/pro/u;
.super Ljava/lang/Object;
.source "ViewPageTracker.java"
# static fields
.field private static final c:I = 0x5
.field private static d:Lorg/json/JSONArray;
.field private static e:Ljava/lang/Object;
# instance fields
.field a:Ljava/util/Stack;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Stack<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field b:Lcom/umeng/analytics/vshelper/a;
.field private final f:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/Long;",
">;"
}
.end annotation
.end field
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 1
new-instance v0, Lorg/json/JSONArray;
invoke-direct {v0}, Lorg/json/JSONArray;-><init>()V
sput-object v0, Lcom/umeng/analytics/pro/u;->d:Lorg/json/JSONArray;
.line 2
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
sput-object v0, Lcom/umeng/analytics/pro/u;->e:Ljava/lang/Object;
return-void
.end method
.method public constructor <init>()V
.registers 2
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
iput-object v0, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
.line 3
new-instance v0, Ljava/util/Stack;
invoke-direct {v0}, Ljava/util/Stack;-><init>()V
iput-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
.line 4
invoke-static {}, Lcom/umeng/analytics/vshelper/PageNameMonitor;->getInstance()Lcom/umeng/analytics/vshelper/PageNameMonitor;
move-result-object v0
iput-object v0, p0, Lcom/umeng/analytics/pro/u;->b:Lcom/umeng/analytics/vshelper/a;
return-void
.end method
.method public static a(Landroid/content/Context;)V
.registers 5
if-eqz p0, :cond_43
.line 1
:try_start_2
new-instance v0, Lorg/json/JSONObject;
invoke-direct {v0}, Lorg/json/JSONObject;-><init>()V
.line 2
sget-object v1, Lcom/umeng/analytics/pro/u;->e:Ljava/lang/Object;
monitor-enter v1
:try_end_a
.catch Ljava/lang/Throwable; {:try_start_2 .. :try_end_a} :catch_43
.line 3
:try_start_a
sget-object v2, Lcom/umeng/analytics/pro/u;->d:Lorg/json/JSONArray;
invoke-virtual {v2}, Lorg/json/JSONArray;->toString()Ljava/lang/String;
move-result-object v2
.line 4
new-instance v3, Lorg/json/JSONArray;
invoke-direct {v3}, Lorg/json/JSONArray;-><init>()V
sput-object v3, Lcom/umeng/analytics/pro/u;->d:Lorg/json/JSONArray;
.line 5
monitor-exit v1
:try_end_18
.catchall {:try_start_a .. :try_end_18} :catchall_40
.line 6
:try_start_18
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v1
if-lez v1, :cond_43
.line 7
new-instance v1, Lorg/json/JSONArray;
invoke-direct {v1, v2}, Lorg/json/JSONArray;-><init>(Ljava/lang/String;)V
const-string v2, "__a"
.line 8
invoke-virtual {v0, v2, v1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
.line 9
invoke-virtual {v0}, Lorg/json/JSONObject;->length()I
move-result v1
if-lez v1, :cond_43
.line 10
invoke-static {p0}, Lcom/umeng/analytics/pro/h;->a(Landroid/content/Context;)Lcom/umeng/analytics/pro/h;
move-result-object p0
invoke-static {}, Lcom/umeng/analytics/pro/t;->a()Lcom/umeng/analytics/pro/t;
move-result-object v1
invoke-virtual {v1}, Lcom/umeng/analytics/pro/t;->c()Ljava/lang/String;
move-result-object v1
sget-object v2, Lcom/umeng/analytics/pro/h$a;->b:Lcom/umeng/analytics/pro/h$a;
invoke-virtual {p0, v1, v0, v2}, Lcom/umeng/analytics/pro/h;->a(Ljava/lang/String;Lorg/json/JSONObject;Lcom/umeng/analytics/pro/h$a;)Z
:try_end_3f
.catch Ljava/lang/Throwable; {:try_start_18 .. :try_end_3f} :catch_43
goto :goto_43
:catchall_40
move-exception p0
.line 11
:try_start_41
monitor-exit v1
:try_end_42
.catchall {:try_start_41 .. :try_end_42} :catchall_40
:try_start_42
throw p0
:try_end_43
.catch Ljava/lang/Throwable; {:try_start_42 .. :try_end_43} :catch_43
:catch_43
:cond_43
:goto_43
return-void
.end method
# virtual methods
.method protected a()I
.registers 2
const/4 v0, 0x2
return v0
.end method
.method public a(Ljava/lang/String;)V
.registers 11
.line 12
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_57
.line 13
invoke-static {}, Lcom/umeng/commonsdk/UMConfigure;->isDebugLog()Z
move-result v0
if-eqz v0, :cond_32
.line 14
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->size()I
move-result v0
if-eqz v0, :cond_32
.line 15
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->peek()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
const/4 v1, 0x1
.line 16
new-array v5, v1, [Ljava/lang/String;
const/4 v2, 0x0
const-string v3, "@"
aput-object v3, v5, v2
.line 17
new-array v6, v1, [Ljava/lang/String;
aput-object v0, v6, v2
.line 18
sget-object v2, Lcom/umeng/analytics/pro/i;->F:Ljava/lang/String;
const/4 v3, 0x0
const/4 v7, 0x0
const/4 v8, 0x0
const-string v4, "\\|"
invoke-static/range {v2 .. v8}, Lcom/umeng/commonsdk/debug/UMLog;->aq(Ljava/lang/String;ILjava/lang/String;[Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/String;)V
.line 19
:cond_32
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->b:Lcom/umeng/analytics/vshelper/a;
invoke-interface {v0, p1}, Lcom/umeng/analytics/vshelper/a;->customPageBegin(Ljava/lang/String;)V
.line 20
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
monitor-enter v0
.line 21
:try_start_3a
iget-object v1, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
invoke-interface {v1, p1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 22
invoke-static {}, Lcom/umeng/commonsdk/UMConfigure;->isDebugLog()Z
move-result v1
if-eqz v1, :cond_52
.line 23
iget-object v1, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v1, p1}, Ljava/util/Stack;->push(Ljava/lang/Object;)Ljava/lang/Object;
.line 24
:cond_52
monitor-exit v0
goto :goto_57
:catchall_54
move-exception p1
monitor-exit v0
:try_end_56
.catchall {:try_start_3a .. :try_end_56} :catchall_54
throw p1
:cond_57
:goto_57
return-void
.end method
.method public b()V
.registers 12
.line 33
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
monitor-enter v0
.line 34
:try_start_3
iget-object v1, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v1
invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v1
const/4 v2, 0x0
const-wide/16 v3, 0x0
:cond_10
:goto_10
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v5
if-eqz v5, :cond_3e
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/util/Map$Entry;
.line 35
invoke-interface {v5}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v6
check-cast v6, Ljava/lang/Long;
invoke-virtual {v6}, Ljava/lang/Long;->longValue()J
move-result-wide v6
cmp-long v8, v6, v3
if-lez v8, :cond_10
.line 36
invoke-interface {v5}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/Long;
invoke-virtual {v2}, Ljava/lang/Long;->longValue()J
move-result-wide v2
.line 37
invoke-interface {v5}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/lang/String;
move-wide v9, v2
move-object v2, v4
move-wide v3, v9
goto :goto_10
.line 38
:cond_3e
monitor-exit v0
:try_end_3f
.catchall {:try_start_3 .. :try_end_3f} :catchall_45
if-eqz v2, :cond_44
.line 39
invoke-virtual {p0, v2}, Lcom/umeng/analytics/pro/u;->b(Ljava/lang/String;)V
:cond_44
return-void
:catchall_45
move-exception v1
.line 40
:try_start_46
monitor-exit v0
:try_end_47
.catchall {:try_start_46 .. :try_end_47} :catchall_45
goto :goto_49
:goto_48
throw v1
:goto_49
goto :goto_48
.end method
.method public b(Ljava/lang/String;)V
.registers 12
.line 1
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-nez v0, :cond_d3
.line 2
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v0
const/4 v1, 0x0
const/4 v2, 0x1
if-eqz v0, :cond_b1
.line 3
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
monitor-enter v0
.line 4
:try_start_13
iget-object v3, p0, Lcom/umeng/analytics/pro/u;->f:Ljava/util/Map;
invoke-interface {v3, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/Long;
.line 5
monitor-exit v0
:try_end_1c
.catchall {:try_start_13 .. :try_end_1c} :catchall_ae
if-nez v3, :cond_1f
return-void
.line 6
:cond_1f
invoke-static {}, Lcom/umeng/commonsdk/UMConfigure;->isDebugLog()Z
move-result v0
if-eqz v0, :cond_3e
.line 7
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->size()I
move-result v0
if-lez v0, :cond_3e
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->peek()Ljava/lang/Object;
move-result-object v0
invoke-virtual {p1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_3e
.line 8
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->pop()Ljava/lang/Object;
.line 9
:cond_3e
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v4
invoke-virtual {v3}, Ljava/lang/Long;->longValue()J
move-result-wide v6
sub-long/2addr v4, v6
.line 10
sget-object v6, Lcom/umeng/analytics/pro/u;->e:Ljava/lang/Object;
monitor-enter v6
.line 11
:try_start_4a
new-instance v0, Lorg/json/JSONObject;
invoke-direct {v0}, Lorg/json/JSONObject;-><init>()V
const-string v7, "page_name"
.line 12
invoke-virtual {v0, v7, p1}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v7, "duration"
.line 13
invoke-virtual {v0, v7, v4, v5}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
const-string v4, "page_start"
.line 14
invoke-virtual {v0, v4, v3}, Lorg/json/JSONObject;->put(Ljava/lang/String;Ljava/lang/Object;)Lorg/json/JSONObject;
const-string v3, "type"
.line 15
invoke-virtual {p0}, Lcom/umeng/analytics/pro/u;->a()I
move-result v4
invoke-virtual {v0, v3, v4}, Lorg/json/JSONObject;->put(Ljava/lang/String;I)Lorg/json/JSONObject;
.line 16
sget-object v3, Lcom/umeng/analytics/pro/u;->d:Lorg/json/JSONArray;
invoke-virtual {v3, v0}, Lorg/json/JSONArray;->put(Ljava/lang/Object;)Lorg/json/JSONArray;
.line 17
sget-object v0, Lcom/umeng/analytics/pro/u;->d:Lorg/json/JSONArray;
invoke-virtual {v0}, Lorg/json/JSONArray;->length()I
move-result v0
const/4 v3, 0x5
if-lt v0, v3, :cond_88
const/4 v0, 0x0
.line 18
invoke-static {v0}, Lcom/umeng/commonsdk/service/UMGlobalContext;->getAppContext(Landroid/content/Context;)Landroid/content/Context;
move-result-object v3
if-eqz v3, :cond_88
const/16 v4, 0x1003
.line 19
invoke-static {v3}, Lcom/umeng/analytics/CoreProtocol;->getInstance(Landroid/content/Context;)Lcom/umeng/analytics/CoreProtocol;
move-result-object v5
invoke-static {v3, v4, v5, v0}, Lcom/umeng/commonsdk/framework/UMWorkDispatch;->sendEvent(Landroid/content/Context;ILcom/umeng/commonsdk/framework/UMLogDataProtocol;Ljava/lang/Object;)V
:try_end_85
.catch Ljava/lang/Throwable; {:try_start_4a .. :try_end_85} :catch_88
.catchall {:try_start_4a .. :try_end_85} :catchall_86
goto :goto_88
:catchall_86
move-exception p1
goto :goto_ac
.line 20
:catch_88
:cond_88
:goto_88
:try_start_88
monitor-exit v6
:try_end_89
.catchall {:try_start_88 .. :try_end_89} :catchall_86
.line 21
invoke-static {}, Lcom/umeng/commonsdk/UMConfigure;->isDebugLog()Z
move-result v0
if-eqz v0, :cond_d3
.line 22
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->size()I
move-result v0
if-eqz v0, :cond_d3
.line 23
new-array v6, v2, [Ljava/lang/String;
const-string v0, "@"
aput-object v0, v6, v1
.line 24
new-array v7, v2, [Ljava/lang/String;
aput-object p1, v7, v1
.line 25
sget-object v3, Lcom/umeng/analytics/pro/i;->E:Ljava/lang/String;
const/4 v4, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
const-string v5, "\\|"
invoke-static/range {v3 .. v9}, Lcom/umeng/commonsdk/debug/UMLog;->aq(Ljava/lang/String;ILjava/lang/String;[Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/String;)V
goto :goto_d3
.line 26
:goto_ac
:try_start_ac
monitor-exit v6
:try_end_ad
.catchall {:try_start_ac .. :try_end_ad} :catchall_86
throw p1
:catchall_ae
move-exception p1
.line 27
:try_start_af
monitor-exit v0
:try_end_b0
.catchall {:try_start_af .. :try_end_b0} :catchall_ae
throw p1
.line 28
:cond_b1
invoke-static {}, Lcom/umeng/commonsdk/UMConfigure;->isDebugLog()Z
move-result v0
if-eqz v0, :cond_d3
.line 29
iget-object v0, p0, Lcom/umeng/analytics/pro/u;->a:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->size()I
move-result v0
if-nez v0, :cond_d3
.line 30
new-array v6, v2, [Ljava/lang/String;
const-string v0, "@"
aput-object v0, v6, v1
.line 31
new-array v7, v2, [Ljava/lang/String;
aput-object p1, v7, v1
.line 32
sget-object v3, Lcom/umeng/analytics/pro/i;->G:Ljava/lang/String;
const/4 v4, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
const-string v5, "\\|"
invoke-static/range {v3 .. v9}, Lcom/umeng/commonsdk/debug/UMLog;->aq(Ljava/lang/String;ILjava/lang/String;[Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/String;[Ljava/lang/String;)V
:cond_d3
:goto_d3
return-void
.end method