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