Files
rr3-apk/smali_classes2/com/glu/plugins/gluanalytics/GluPerformance.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

1636 lines
42 KiB
Smali

.class public Lcom/glu/plugins/gluanalytics/GluPerformance;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/glu/plugins/gluanalytics/IPerformance;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;,
Lcom/glu/plugins/gluanalytics/GluPerformance$SampleTask;,
Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
}
.end annotation
# static fields
.field private static preSDKLoadStartTimeStamp:J
# instance fields
.field final APP_PERFORMANCE:Ljava/lang/String;
.field final LOG_EVENT_SOURCE_SDK:Ljava/lang/String;
.field final LOG_NAME_PERFORMANCE:Ljava/lang/String;
.field private final lock:Ljava/lang/Object;
.field private mActivityManager:Landroid/app/ActivityManager;
.field private mAnalytics:Lcom/glu/plugins/gluanalytics/IAnalytics;
.field private mDevBuild:Z
.field private mExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
.field private mFrameCount:I
.field private mFrameTask:Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;
.field private mHasVersionChanged:Z
.field private mIsFirstLaunch:Z
.field private mLastFrameTime:J
.field private mLatestFPS:D
.field private final mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
.field private mPerfSamples:Ljava/util/HashMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;",
">;"
}
.end annotation
.end field
.field mPreInitSample:Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
.field private mRunning:Z
.field private mSampleInterval:D
.field private mTargetFrameRate:D
# direct methods
.method static constructor <clinit>()V
.locals 0
return-void
.end method
.method public constructor <init>(Landroid/content/Context;DDZDZZ)V
.locals 13
move-object v0, p0
move-wide v1, p2
move-wide/from16 v3, p4
.line 58
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 28
new-instance v5, Ljava/lang/Object;
invoke-direct {v5}, Ljava/lang/Object;-><init>()V
iput-object v5, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->lock:Ljava/lang/Object;
.line 29
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v5
invoke-static {v5}, Lcom/glu/plugins/gluanalytics/util/YLogger;->create(Ljava/lang/Class;)Lcom/glu/plugins/gluanalytics/util/YLogger;
move-result-object v5
iput-object v5, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string v5, "PERFORMANCE"
iput-object v5, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->LOG_NAME_PERFORMANCE:Ljava/lang/String;
const-string v5, "SDK_STANDARD"
iput-object v5, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->LOG_EVENT_SOURCE_SDK:Ljava/lang/String;
const-string v5, "APP_PERFORMANCE"
iput-object v5, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->APP_PERFORMANCE:Ljava/lang/String;
iput-wide v1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mSampleInterval:D
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mTargetFrameRate:D
.line 62
new-instance v6, Ljava/util/HashMap;
invoke-direct {v6}, Ljava/util/HashMap;-><init>()V
iput-object v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
move/from16 v6, p6
iput-boolean v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mDevBuild:Z
move/from16 v6, p9
iput-boolean v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mIsFirstLaunch:Z
move/from16 v6, p10
iput-boolean v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mHasVersionChanged:Z
const-string v6, "activity"
move-object v7, p1
.line 68
invoke-virtual {p1, v6}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v6
check-cast v6, Landroid/app/ActivityManager;
iput-object v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mActivityManager:Landroid/app/ActivityManager;
const/4 v6, 0x0
iput v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameCount:I
const-wide/16 v6, 0x0
iput-wide v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLastFrameTime:J
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLatestFPS:D
.line 73
new-instance v3, Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;
invoke-direct {v3, p0}, Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;-><init>(Lcom/glu/plugins/gluanalytics/GluPerformance;)V
iput-object v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameTask:Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;
.line 75
new-instance v6, Ljava/util/concurrent/ScheduledThreadPoolExecutor;
const/4 v3, 0x1
invoke-direct {v6, v3}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;-><init>(I)V
iput-object v6, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
.line 76
new-instance v7, Lcom/glu/plugins/gluanalytics/GluPerformance$SampleTask;
invoke-direct {v7, p0}, Lcom/glu/plugins/gluanalytics/GluPerformance$SampleTask;-><init>(Lcom/glu/plugins/gluanalytics/GluPerformance;)V
const-wide/16 v8, 0x0
const-wide v10, 0x408f400000000000L # 1000.0
mul-double/2addr v1, v10
double-to-long v10, v1
sget-object v12, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual/range {v6 .. v12}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
iput-boolean v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
const/4 v1, 0x0
iput-object v1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPreInitSample:Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
move-wide/from16 v2, p7
.line 80
invoke-virtual {p0, v2, v3}, Lcom/glu/plugins/gluanalytics/GluPerformance;->logPreBootSample(D)V
const/4 v2, 0x7
.line 82
invoke-virtual {p0, v5, v2, v1}, Lcom/glu/plugins/gluanalytics/GluPerformance;->perfSampleStart(Ljava/lang/String;ILjava/util/Map;)V
return-void
.end method
.method public static synthetic access$100(Lcom/glu/plugins/gluanalytics/GluPerformance;)Lcom/glu/plugins/gluanalytics/util/YLogger;
.locals 0
.line 24
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
return-object p0
.end method
.method public static synthetic access$1000(Lcom/glu/plugins/gluanalytics/GluPerformance;)D
.locals 2
.line 24
invoke-direct {p0}, Lcom/glu/plugins/gluanalytics/GluPerformance;->getUsedMemory()D
move-result-wide v0
return-wide v0
.end method
.method public static synthetic access$1100(Lcom/glu/plugins/gluanalytics/GluPerformance;)D
.locals 2
.line 24
iget-wide v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mTargetFrameRate:D
return-wide v0
.end method
.method public static synthetic access$300(Lcom/glu/plugins/gluanalytics/GluPerformance;)J
.locals 2
.line 24
iget-wide v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLastFrameTime:J
return-wide v0
.end method
.method public static synthetic access$302(Lcom/glu/plugins/gluanalytics/GluPerformance;J)J
.locals 0
.line 24
iput-wide p1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLastFrameTime:J
return-wide p1
.end method
.method public static synthetic access$400(Lcom/glu/plugins/gluanalytics/GluPerformance;)I
.locals 0
.line 24
iget p0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameCount:I
return p0
.end method
.method public static synthetic access$402(Lcom/glu/plugins/gluanalytics/GluPerformance;I)I
.locals 0
.line 24
iput p1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameCount:I
return p1
.end method
.method public static synthetic access$408(Lcom/glu/plugins/gluanalytics/GluPerformance;)I
.locals 2
.line 24
iget v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameCount:I
add-int/lit8 v1, v0, 0x1
iput v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameCount:I
return v0
.end method
.method public static synthetic access$500(Lcom/glu/plugins/gluanalytics/GluPerformance;)D
.locals 2
.line 24
iget-wide v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mSampleInterval:D
return-wide v0
.end method
.method public static synthetic access$600(Lcom/glu/plugins/gluanalytics/GluPerformance;)D
.locals 2
.line 24
iget-wide v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLatestFPS:D
return-wide v0
.end method
.method public static synthetic access$602(Lcom/glu/plugins/gluanalytics/GluPerformance;D)D
.locals 0
.line 24
iput-wide p1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLatestFPS:D
return-wide p1
.end method
.method public static synthetic access$700(Lcom/glu/plugins/gluanalytics/GluPerformance;)Ljava/lang/Object;
.locals 0
.line 24
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->lock:Ljava/lang/Object;
return-object p0
.end method
.method public static synthetic access$800(Lcom/glu/plugins/gluanalytics/GluPerformance;)Ljava/util/HashMap;
.locals 0
.line 24
iget-object p0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
return-object p0
.end method
.method public static synthetic access$900(Lcom/glu/plugins/gluanalytics/GluPerformance;)Z
.locals 0
.line 24
iget-boolean p0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
return p0
.end method
.method private flush(Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;)V
.locals 11
if-nez p1, :cond_0
return-void
.line 311
:cond_0
iget-object v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->userData:Ljava/util/Map;
if-nez v0, :cond_1
.line 312
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
:goto_0
move-object v8, v0
goto :goto_1
.line 314
:cond_1
new-instance v0, Ljava/util/HashMap;
iget-object v1, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->userData:Ljava/util/Map;
invoke-direct {v0, v1}, Ljava/util/HashMap;-><init>(Ljava/util/Map;)V
goto :goto_0
:goto_1
iget-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mIsFirstLaunch:Z
const-string v1, "true"
if-eqz v0, :cond_2
const-string v0, "isFirstLaunch"
.line 317
invoke-virtual {v8, v0, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_2
iget-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mHasVersionChanged:Z
if-eqz v0, :cond_3
const-string v0, "wasVersionUpdated"
.line 320
invoke-virtual {v8, v0, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 322
:cond_3
iget v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
and-int/lit8 v0, v0, 0x2
const-wide/16 v1, 0x0
if-eqz v0, :cond_6
iget-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mDevBuild:Z
if-eqz v0, :cond_4
.line 324
iget-wide v3, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startMemory:D
invoke-static {v3, v4}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
const-string v3, "start_mem"
invoke-virtual {v8, v3, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 325
iget-wide v3, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->endMemory:D
invoke-static {v3, v4}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
const-string v3, "end_mem"
invoke-virtual {v8, v3, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 327
:cond_4
iget-wide v3, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->sampleCount:J
cmp-long v0, v3, v1
const-string v3, "avg_mem"
const-string v4, "max_mem"
if-eqz v0, :cond_5
.line 328
iget-wide v5, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->maxMemory:D
invoke-static {v5, v6}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
invoke-virtual {v8, v4, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 329
iget-wide v4, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->totalMemory:D
iget-wide v6, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->sampleCount:J
long-to-double v6, v6
div-double/2addr v4, v6
invoke-static {v4, v5}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
invoke-virtual {v8, v3, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_2
:cond_5
iget-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mDevBuild:Z
if-eqz v0, :cond_6
.line 331
iget-wide v5, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startMemory:D
iget-wide v9, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->endMemory:D
invoke-static {v5, v6, v9, v10}, Ljava/lang/Math;->max(DD)D
move-result-wide v5
invoke-static {v5, v6}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
invoke-virtual {v8, v4, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 332
iget-wide v4, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startMemory:D
iget-wide v6, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->endMemory:D
add-double/2addr v4, v6
const-wide/high16 v6, 0x3fe0000000000000L # 0.5
mul-double/2addr v4, v6
invoke-static {v4, v5}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
invoke-virtual {v8, v3, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 335
:cond_6
:goto_2
iget v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
and-int/lit8 v0, v0, 0x4
if-eqz v0, :cond_7
iget-wide v3, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->sampleCount:J
cmp-long v0, v3, v1
if-eqz v0, :cond_7
.line 336
iget-wide v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->minFPS:D
invoke-static {v0, v1}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
const-string v1, "min_fps"
invoke-virtual {v8, v1, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 337
iget-wide v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->totalFPS:D
iget-wide v2, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->sampleCount:J
long-to-double v2, v2
div-double/2addr v0, v2
invoke-static {v0, v1}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
const-string v1, "avg_fps"
invoke-virtual {v8, v1, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
iget-wide v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mTargetFrameRate:D
.line 338
invoke-static {v0, v1}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
const-string v1, "target_fps"
invoke-virtual {v8, v1, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 340
:cond_7
iget v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
and-int/lit8 v0, v0, 0x1
if-eqz v0, :cond_9
.line 341
iget-wide v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->preInitTime:D
const-wide/16 v2, 0x0
cmpl-double v2, v0, v2
const-string v3, "time_ms"
if-lez v2, :cond_8
.line 342
invoke-static {v0, v1}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
invoke-virtual {v8, v3, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_3
.line 344
:cond_8
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v0
long-to-double v0, v0
iget-wide v4, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startTimeStamp:D
sub-double/2addr v0, v4
iget-wide v4, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->pausedTimeTotal:D
sub-double/2addr v0, v4
invoke-static {v0, v1}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
invoke-virtual {v8, v3, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 347
:goto_3
iget-boolean v0, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isSuspended:Z
if-eqz v0, :cond_9
const-string v0, "is_suspended"
sget-object v1, Ljava/lang/Boolean;->TRUE:Ljava/lang/Boolean;
.line 348
invoke-virtual {v8, v0, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:cond_9
iget-object v2, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mAnalytics:Lcom/glu/plugins/gluanalytics/IAnalytics;
.line 352
iget-object v3, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->placement:Ljava/lang/String;
const-string v4, "PERFORMANCE"
iget p1, p1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v5
const/4 v6, 0x0
const-string v7, "SDK_STANDARD"
invoke-interface/range {v2 .. v8}, Lcom/glu/plugins/gluanalytics/IAnalytics;->internal_perfEvent(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;)V
return-void
.end method
.method private getUsedMemory()D
.locals 2
.line 87
invoke-static {}, Landroid/os/Process;->myPid()I
move-result v0
filled-new-array {v0}, [I
move-result-object v0
iget-object v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mActivityManager:Landroid/app/ActivityManager;
.line 88
invoke-virtual {v1, v0}, Landroid/app/ActivityManager;->getProcessMemoryInfo([I)[Landroid/os/Debug$MemoryInfo;
move-result-object v0
const/4 v1, 0x0
.line 89
aget-object v0, v0, v1
invoke-virtual {v0}, Landroid/os/Debug$MemoryInfo;->getTotalPss()I
move-result v0
int-to-float v0, v0
const/high16 v1, 0x44800000 # 1024.0f
div-float/2addr v0, v1
float-to-double v0, v0
return-wide v0
.end method
.method public static perfSampleLogLaunchOverhead()V
.locals 2
.line 281
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v0
sput-wide v0, Lcom/glu/plugins/gluanalytics/GluPerformance;->preSDKLoadStartTimeStamp:J
return-void
.end method
# virtual methods
.method public destroy()V
.locals 2
iget-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
if-eqz v0, :cond_0
const-string v0, "APP_PERFORMANCE"
const/4 v1, 0x0
.line 95
invoke-virtual {p0, v0, v1}, Lcom/glu/plugins/gluanalytics/GluPerformance;->perfSampleEnd(Ljava/lang/String;Ljava/util/Map;)V
const/4 v0, 0x0
iput-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
:cond_0
return-void
.end method
.method public internal_LogLaunchOverhead()V
.locals 1
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPreInitSample:Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
if-eqz v0, :cond_0
.line 151
invoke-direct {p0, v0}, Lcom/glu/plugins/gluanalytics/GluPerformance;->flush(Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;)V
const/4 v0, 0x0
iput-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPreInitSample:Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
:cond_0
return-void
.end method
.method public internal_SetAnalytics(Lcom/glu/plugins/gluanalytics/IAnalytics;)V
.locals 0
iput-object p1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mAnalytics:Lcom/glu/plugins/gluanalytics/IAnalytics;
return-void
.end method
.method public logPreBootSample(D)V
.locals 5
const-wide/16 v0, 0x0
sget-wide v2, Lcom/glu/plugins/gluanalytics/GluPerformance;->preSDKLoadStartTimeStamp:J
cmp-long v0, v0, v2
const-wide/16 v1, 0x0
if-nez v0, :cond_0
cmpl-double v0, p1, v1
if-lez v0, :cond_2
.line 287
:cond_0
new-instance v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
const/4 v3, 0x0
invoke-direct {v0, p0, v3}, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;-><init>(Lcom/glu/plugins/gluanalytics/GluPerformance;Lcom/glu/plugins/gluanalytics/GluPerformance$1;)V
iput-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPreInitSample:Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
const-string v4, "LAUNCH_OVERHEAD"
iput-object v4, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->placement:Ljava/lang/String;
iput-object v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->userData:Ljava/util/Map;
const/4 v3, 0x1
iput v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
cmpl-double v1, p1, v1
if-lez v1, :cond_1
const-wide v1, 0x408f400000000000L # 1000.0
mul-double/2addr p1, v1
iput-wide p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->preInitTime:D
goto :goto_0
:cond_1
sget-wide p1, Lcom/glu/plugins/gluanalytics/GluPerformance;->preSDKLoadStartTimeStamp:J
long-to-double p1, p1
iput-wide p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startTimeStamp:D
:goto_0
const/4 p1, 0x0
iput-boolean p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isSuspended:Z
:cond_2
return-void
.end method
.method public onPause()V
.locals 6
iget-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
const/4 v1, 0x0
if-eqz v0, :cond_0
const-string v0, "APP_PERFORMANCE"
const/4 v2, 0x0
.line 123
invoke-virtual {p0, v0, v2}, Lcom/glu/plugins/gluanalytics/GluPerformance;->perfSampleEnd(Ljava/lang/String;Ljava/util/Map;)V
iput-boolean v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
:cond_0
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameTask:Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;
.line 126
invoke-virtual {v0}, Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;->end()V
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->lock:Ljava/lang/Object;
.line 128
monitor-enter v0
:try_start_0
iget-object v2, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 129
invoke-virtual {v2}, Ljava/util/HashMap;->entrySet()Ljava/util/Set;
move-result-object v2
invoke-interface {v2}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v2
.line 130
:cond_1
:goto_0
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v3
if-eqz v3, :cond_2
.line 131
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/util/Map$Entry;
.line 132
invoke-interface {v3}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
const/4 v5, 0x1
.line 133
iput-boolean v5, v4, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isSuspended:Z
.line 134
iget-object v4, v4, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->userData:Ljava/util/Map;
if-eqz v4, :cond_1
const-string v5, "autoPause"
invoke-interface {v4, v5}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v4
if-eqz v4, :cond_1
.line 135
invoke-interface {v3}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
invoke-virtual {p0, v3, v1}, Lcom/glu/plugins/gluanalytics/GluPerformance;->perfSampleAction(Ljava/lang/String;I)Z
goto :goto_0
:catchall_0
move-exception v1
goto :goto_1
.line 138
:cond_2
monitor-exit v0
return-void
:goto_1
monitor-exit v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
throw v1
.end method
.method public onResume()V
.locals 5
const/4 v0, 0x0
iput v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameCount:I
const-wide/16 v0, 0x0
iput-wide v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLastFrameTime:J
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mFrameTask:Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;
.line 104
invoke-virtual {v0}, Lcom/glu/plugins/gluanalytics/GluPerformance$FrameTask;->start()V
iget-boolean v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
const/4 v1, 0x1
if-nez v0, :cond_0
iput-boolean v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mRunning:Z
const/4 v0, 0x7
const/4 v2, 0x0
const-string v3, "APP_PERFORMANCE"
.line 108
invoke-virtual {p0, v3, v0, v2}, Lcom/glu/plugins/gluanalytics/GluPerformance;->perfSampleStart(Ljava/lang/String;ILjava/util/Map;)V
:cond_0
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 111
invoke-virtual {v0}, Ljava/util/HashMap;->keySet()Ljava/util/Set;
move-result-object v0
.line 112
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_1
:goto_0
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_2
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
iget-object v3, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 113
invoke-virtual {v3, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
.line 114
iget-object v3, v3, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->userData:Ljava/util/Map;
if-eqz v3, :cond_1
const-string v4, "autoPause"
invoke-interface {v3, v4}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v3
if-eqz v3, :cond_1
.line 115
invoke-virtual {p0, v2, v1}, Lcom/glu/plugins/gluanalytics/GluPerformance;->perfSampleAction(Ljava/lang/String;I)Z
goto :goto_0
:cond_2
return-void
.end method
.method public perfGetValues()Lcom/glu/plugins/gluanalytics/PerfMeasure;
.locals 9
.line 210
new-instance v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;
invoke-direct {v0}, Lcom/glu/plugins/gluanalytics/PerfMeasure;-><init>()V
iget-object v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
const-string v2, "APP_PERFORMANCE"
.line 212
invoke-virtual {v1, v2}, Ljava/util/HashMap;->containsKey(Ljava/lang/Object;)Z
move-result v1
iget-object v3, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 213
invoke-virtual {v3, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
const-wide/high16 v3, -0x4010000000000000L # -1.0
if-eqz v1, :cond_1
.line 215
iget v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
and-int/lit8 v5, v5, 0x4
if-eqz v5, :cond_1
iget-boolean v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
if-eqz v5, :cond_0
goto :goto_0
.line 221
:cond_0
iget-wide v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->totalFPS:D
iget-wide v7, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->sampleCount:J
long-to-double v7, v7
div-double/2addr v5, v7
iput-wide v5, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->averageFPS:D
.line 222
iget-wide v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->lastFPS:D
iput-wide v5, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->lastFPS:D
.line 223
iget-wide v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->minFPS:D
iput-wide v5, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->minFPS:D
.line 224
iget-wide v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->maxFPS:D
iput-wide v5, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->maxFPS:D
goto :goto_1
:cond_1
:goto_0
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->averageFPS:D
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->lastFPS:D
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->minFPS:D
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->maxFPS:D
:goto_1
if-eqz v1, :cond_3
.line 227
iget v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
and-int/lit8 v5, v5, 0x2
if-eqz v5, :cond_3
iget-boolean v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
if-eqz v5, :cond_2
goto :goto_2
.line 232
:cond_2
iget-wide v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startMemory:D
iput-wide v5, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->startMem:D
.line 233
iget-wide v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->maxMemory:D
iput-wide v5, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->maxMem:D
.line 234
invoke-direct {p0}, Lcom/glu/plugins/gluanalytics/GluPerformance;->getUsedMemory()D
move-result-wide v5
iput-wide v5, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->currentMem:D
goto :goto_3
:cond_3
:goto_2
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->startMem:D
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->maxMem:D
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->currentMem:D
:goto_3
if-eqz v1, :cond_5
.line 237
iget v1, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
and-int/lit8 v1, v1, 0x2
if-eqz v1, :cond_5
iget-boolean v1, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
if-eqz v1, :cond_4
goto :goto_4
.line 240
:cond_4
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v3
long-to-double v3, v3
iget-wide v5, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startTimeStamp:D
sub-double/2addr v3, v5
iget-wide v1, v2, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->pausedTimeTotal:D
sub-double/2addr v3, v1
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->time:D
goto :goto_5
:cond_5
:goto_4
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/PerfMeasure;->time:D
:goto_5
return-object v0
.end method
.method public perfSampleAction(Ljava/lang/String;I)Z
.locals 7
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 248
invoke-virtual {v0, p1}, Ljava/util/HashMap;->containsKey(Ljava/lang/Object;)Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_0
return v1
:cond_0
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 252
invoke-virtual {v0, p1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
const/4 v2, 0x1
if-eqz p2, :cond_4
if-eq p2, v2, :cond_2
const/4 v0, 0x2
if-eq p2, v0, :cond_1
goto :goto_0
:cond_1
iget-object p2, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->lock:Ljava/lang/Object;
.line 268
monitor-enter p2
:try_start_0
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 269
invoke-virtual {v0, p1}, Ljava/util/HashMap;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 270
monitor-exit p2
goto :goto_0
:catchall_0
move-exception p1
monitor-exit p2
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
throw p1
.line 262
:cond_2
iget-boolean p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
if-nez p1, :cond_3
return v1
.line 264
:cond_3
iput-boolean v1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
.line 265
iget-wide p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->pausedTimeTotal:D
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v3
long-to-double v3, v3
iget-wide v5, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startPausedTimeStamp:D
sub-double/2addr v3, v5
add-double/2addr p1, v3
iput-wide p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->pausedTimeTotal:D
goto :goto_0
.line 256
:cond_4
iget-boolean p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
if-eqz p1, :cond_5
return v1
.line 258
:cond_5
iput-boolean v2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
.line 259
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide p1
long-to-double p1, p1
iput-wide p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startPausedTimeStamp:D
:goto_0
return v2
.end method
.method public perfSampleEnd(Ljava/lang/String;Ljava/util/Map;)V
.locals 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/String;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"*>;)V"
}
.end annotation
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->lock:Ljava/lang/Object;
.line 193
monitor-enter v0
:try_start_0
iget-object v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 194
invoke-virtual {v1, p1}, Ljava/util/HashMap;->containsKey(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_0
iget-object p2, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string v1, "PerfSampleEnd"
const/4 v2, 0x4
new-array v2, v2, [Ljava/lang/Object;
const-string v3, "m"
const/4 v4, 0x0
aput-object v3, v2, v4
const-string v3, "placement is not exist, ignored."
const/4 v4, 0x1
aput-object v3, v2, v4
const-string v3, "placement"
const/4 v4, 0x2
aput-object v3, v2, v4
const/4 v3, 0x3
aput-object p1, v2, v3
.line 195
invoke-virtual {p2, v1, v2}, Lcom/glu/plugins/gluanalytics/util/YLogger;->e(Ljava/lang/String;[Ljava/lang/Object;)V
.line 196
monitor-exit v0
return-void
:catchall_0
move-exception p1
goto :goto_1
:cond_0
iget-object v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 198
invoke-virtual {v1, p1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
iget-object v2, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 199
invoke-virtual {v2, p1}, Ljava/util/HashMap;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 200
monitor-exit v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
if-eqz p2, :cond_1
.line 202
invoke-interface {p2}, Ljava/util/Map;->size()I
move-result p1
if-eqz p1, :cond_1
.line 203
iput-object p2, v1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->userData:Ljava/util/Map;
:cond_1
iget-boolean p1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mDevBuild:Z
if-eqz p1, :cond_2
.line 204
invoke-direct {p0}, Lcom/glu/plugins/gluanalytics/GluPerformance;->getUsedMemory()D
move-result-wide p1
goto :goto_0
:cond_2
const-wide/16 p1, 0x0
:goto_0
iput-wide p1, v1, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->endMemory:D
.line 205
invoke-direct {p0, v1}, Lcom/glu/plugins/gluanalytics/GluPerformance;->flush(Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;)V
return-void
.line 200
:goto_1
:try_start_1
monitor-exit v0
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
throw p1
.end method
.method public perfSampleStart(Ljava/lang/String;ILjava/util/Map;)V
.locals 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/String;",
"I",
"Ljava/util/Map<",
"Ljava/lang/String;",
"*>;)V"
}
.end annotation
iget-object v0, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->lock:Ljava/lang/Object;
.line 158
monitor-enter v0
:try_start_0
iget-object v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 159
invoke-virtual {v1, p1}, Ljava/util/HashMap;->containsKey(Ljava/lang/Object;)Z
move-result v1
const/4 v2, 0x0
if-eqz v1, :cond_0
iget-object p2, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mLog:Lcom/glu/plugins/gluanalytics/util/YLogger;
const-string p3, "PerfSampleStart"
const/4 v1, 0x4
new-array v1, v1, [Ljava/lang/Object;
const-string v3, "m"
aput-object v3, v1, v2
const-string v2, "placement has already exist, ignored."
const/4 v3, 0x1
aput-object v2, v1, v3
const-string v2, "placement"
const/4 v3, 0x2
aput-object v2, v1, v3
const/4 v2, 0x3
aput-object p1, v1, v2
.line 160
invoke-virtual {p2, p3, v1}, Lcom/glu/plugins/gluanalytics/util/YLogger;->e(Ljava/lang/String;[Ljava/lang/Object;)V
.line 161
monitor-exit v0
return-void
:catchall_0
move-exception p1
goto :goto_1
.line 163
:cond_0
monitor-exit v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
.line 165
new-instance v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;
const/4 v1, 0x0
invoke-direct {v0, p0, v1}, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;-><init>(Lcom/glu/plugins/gluanalytics/GluPerformance;Lcom/glu/plugins/gluanalytics/GluPerformance$1;)V
iput-object p1, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->placement:Ljava/lang/String;
iput p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->type:I
iput-object p3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->userData:Ljava/util/Map;
const-wide/16 p2, 0x0
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->maxMemory:D
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->totalMemory:D
iget-boolean v1, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mDevBuild:Z
if-eqz v1, :cond_1
.line 171
invoke-direct {p0}, Lcom/glu/plugins/gluanalytics/GluPerformance;->getUsedMemory()D
move-result-wide v3
goto :goto_0
:cond_1
move-wide v3, p2
:goto_0
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startMemory:D
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->endMemory:D
iget-wide v3, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mTargetFrameRate:D
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->minFPS:D
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->maxFPS:D
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->totalFPS:D
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->lastFPS:D
const-wide/16 v3, 0x0
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->sampleCount:J
.line 178
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v3
long-to-double v3, v3
iput-wide v3, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startTimeStamp:D
iput-boolean v2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isSuspended:Z
iput-boolean v2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->isPaused:Z
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->startPausedTimeStamp:D
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->pausedTimeTotal:D
iput-wide p2, v0, Lcom/glu/plugins/gluanalytics/GluPerformance$PerfSample;->preInitTime:D
iget-object p2, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->lock:Ljava/lang/Object;
.line 185
monitor-enter p2
:try_start_1
iget-object p3, p0, Lcom/glu/plugins/gluanalytics/GluPerformance;->mPerfSamples:Ljava/util/HashMap;
.line 186
invoke-virtual {p3, p1, v0}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 187
monitor-exit p2
return-void
:catchall_1
move-exception p1
monitor-exit p2
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_1
throw p1
.line 163
:goto_1
:try_start_2
monitor-exit v0
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_0
throw p1
.end method