b.smali
.class public Lcom/hz/xloglite/e/b;
.super Ljava/lang/Object;
.source ""
# static fields
.field public static a:Lcom/hz/xloglite/e/b;
# instance fields
.field public b:Lcom/hz/xloglite/e/a;
.field public c:Ljava/text/SimpleDateFormat;
# direct methods
.method public constructor <init>(Landroid/content/Context;)V
.registers 4
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v0, Ljava/text/SimpleDateFormat;
const-string v1, "yyyy-MM-dd HH:mm:ss"
invoke-direct {v0, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;)V
iput-object v0, p0, Lcom/hz/xloglite/e/b;->c:Ljava/text/SimpleDateFormat;
invoke-static {p1}, Lcom/hz/xloglite/e/a;->a(Landroid/content/Context;)Lcom/hz/xloglite/e/a;
move-result-object v0
iput-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
return-void
.end method
.method public static a(Landroid/content/Context;)Lcom/hz/xloglite/e/b;
.registers 4
sget-object v0, Lcom/hz/xloglite/e/b;->a:Lcom/hz/xloglite/e/b;
if-nez v0, :cond_17
const-class v1, Lcom/hz/xloglite/e/b;
monitor-enter v1
:try_start_7
sget-object v0, Lcom/hz/xloglite/e/b;->a:Lcom/hz/xloglite/e/b;
if-nez v0, :cond_16
new-instance v0, Lcom/hz/xloglite/e/b;
invoke-virtual {p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v2
invoke-direct {v0, v2}, Lcom/hz/xloglite/e/b;-><init>(Landroid/content/Context;)V
sput-object v0, Lcom/hz/xloglite/e/b;->a:Lcom/hz/xloglite/e/b;
:cond_16
monitor-exit v1
:try_end_17
.catchall {:try_start_7 .. :try_end_17} :catchall_1a
:cond_17
sget-object v0, Lcom/hz/xloglite/e/b;->a:Lcom/hz/xloglite/e/b;
return-object v0
:catchall_1a
move-exception v0
:try_start_1b
monitor-exit v1
:try_end_1c
.catchall {:try_start_1b .. :try_end_1c} :catchall_1a
throw v0
.end method
# virtual methods
.method public a()Lorg/json/JSONArray;
.registers 6
const/4 v1, 0x0
new-instance v2, Lorg/json/JSONArray;
invoke-direct {v2}, Lorg/json/JSONArray;-><init>()V
:try_start_6
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
invoke-virtual {v0}, Lcom/hz/xloglite/e/a;->a()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
const-string v3, "select content from hz_app_online_log order by id"
const/4 v4, 0x0
invoke-virtual {v0, v3, v4}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v1
:goto_13
invoke-interface {v1}, Landroid/database/Cursor;->moveToNext()Z
move-result v0
if-eqz v0, :cond_38
const-string v0, "content"
invoke-interface {v1, v0}, Landroid/database/Cursor;->getColumnIndex(Ljava/lang/String;)I
move-result v0
invoke-interface {v1, v0}, Landroid/database/Cursor;->getString(I)Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Lorg/json/JSONArray;->put(Ljava/lang/Object;)Lorg/json/JSONArray;
:try_end_26
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_26} :catch_27
.catchall {:try_start_6 .. :try_end_26} :catchall_40
goto :goto_13
:catch_27
move-exception v0
:try_start_28
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
:try_end_2b
.catchall {:try_start_28 .. :try_end_2b} :catchall_40
if-eqz v1, :cond_30
invoke-interface {v1}, Landroid/database/Cursor;->close()V
:cond_30
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v0, :cond_37
:goto_34
invoke-virtual {v0}, Lcom/hz/xloglite/e/a;->b()V
:cond_37
return-object v2
:cond_38
invoke-interface {v1}, Landroid/database/Cursor;->close()V
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v0, :cond_37
goto :goto_34
:catchall_40
move-exception v0
if-eqz v1, :cond_46
invoke-interface {v1}, Landroid/database/Cursor;->close()V
:cond_46
iget-object v1, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v1, :cond_4d
invoke-virtual {v1}, Lcom/hz/xloglite/e/a;->b()V
:cond_4d
throw v0
.end method
.method public declared-synchronized a(I)V
.registers 5
monitor-enter p0
:try_start_1
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
invoke-virtual {v0}, Lcom/hz/xloglite/e/a;->a()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "delete from hz_app_online_log where id in (select id from hz_app_online_log order by id asc limit "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v2, ")"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
:try_end_23
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_23} :catch_2c
.catchall {:try_start_1 .. :try_end_23} :catchall_35
:try_start_23
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v0, :cond_2a
:goto_27
invoke-virtual {v0}, Lcom/hz/xloglite/e/a;->b()V
:try_end_2a
.catchall {:try_start_23 .. :try_end_2a} :catchall_3e
:cond_2a
monitor-exit p0
return-void
:catch_2c
move-exception v0
:try_start_2d
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
:try_end_30
.catchall {:try_start_2d .. :try_end_30} :catchall_35
:try_start_30
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v0, :cond_2a
goto :goto_27
:catchall_35
move-exception v0
iget-object v1, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v1, :cond_3d
invoke-virtual {v1}, Lcom/hz/xloglite/e/a;->b()V
:cond_3d
throw v0
:try_end_3e
.catchall {:try_start_30 .. :try_end_3e} :catchall_3e
:catchall_3e
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized a(Ljava/lang/String;)V
.registers 9
monitor-enter p0
:try_start_1
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
invoke-virtual {v0}, Lcom/hz/xloglite/e/a;->a()Landroid/database/sqlite/SQLiteDatabase;
move-result-object v0
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
new-instance v1, Landroid/content/ContentValues;
invoke-direct {v1}, Landroid/content/ContentValues;-><init>()V
:try_end_10
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_10} :catch_3d
.catchall {:try_start_1 .. :try_end_10} :catchall_46
:try_start_10
const-string v4, "date"
:try_end_12
.catchall {:try_start_10 .. :try_end_12} :catchall_4f
:try_start_12
iget-object v5, p0, Lcom/hz/xloglite/e/b;->c:Ljava/text/SimpleDateFormat;
new-instance v6, Ljava/util/Date;
invoke-direct {v6, v2, v3}, Ljava/util/Date;-><init>(J)V
invoke-virtual {v5, v6}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v5
invoke-virtual {v1, v4, v5}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
:try_end_20
.catch Ljava/lang/Exception; {:try_start_12 .. :try_end_20} :catch_3d
.catchall {:try_start_12 .. :try_end_20} :catchall_46
:try_start_20
const-string v4, "timestamp"
:try_end_22
.catchall {:try_start_20 .. :try_end_22} :catchall_4f
:try_start_22
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
invoke-virtual {v1, v4, v2}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/Long;)V
const-string v2, "content"
invoke-virtual {v1, v2, p1}, Landroid/content/ContentValues;->put(Ljava/lang/String;Ljava/lang/String;)V
const-string v2, "hz_app_online_log"
const/4 v3, 0x0
invoke-virtual {v0, v2, v3, v1}, Landroid/database/sqlite/SQLiteDatabase;->insert(Ljava/lang/String;Ljava/lang/String;Landroid/content/ContentValues;)J
:try_end_34
.catch Ljava/lang/Exception; {:try_start_22 .. :try_end_34} :catch_3d
.catchall {:try_start_22 .. :try_end_34} :catchall_46
:try_start_34
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v0, :cond_3b
:goto_38
invoke-virtual {v0}, Lcom/hz/xloglite/e/a;->b()V
:try_end_3b
.catchall {:try_start_34 .. :try_end_3b} :catchall_4f
:cond_3b
monitor-exit p0
return-void
:catch_3d
move-exception v0
:try_start_3e
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
:try_end_41
.catchall {:try_start_3e .. :try_end_41} :catchall_46
:try_start_41
iget-object v0, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v0, :cond_3b
goto :goto_38
:catchall_46
move-exception v0
iget-object v1, p0, Lcom/hz/xloglite/e/b;->b:Lcom/hz/xloglite/e/a;
if-eqz v1, :cond_4e
invoke-virtual {v1}, Lcom/hz/xloglite/e/a;->b()V
:cond_4e
throw v0
:try_end_4f
.catchall {:try_start_41 .. :try_end_4f} :catchall_4f
:catchall_4f
move-exception v0
monitor-exit p0
throw v0
.end method