AndroidDatabaseConnection.smali
.class public Lcom/j256/ormlite/android/AndroidDatabaseConnection;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/j256/ormlite/support/DatabaseConnection;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/j256/ormlite/android/AndroidDatabaseConnection$OurSavePoint;
}
.end annotation
# static fields
.field private static final ANDROID_VERSION:Ljava/lang/String; = "VERSION__5.0__"
.field private static final NO_STRING_ARGS:[Ljava/lang/String;
.field private static logger:Lcom/j256/ormlite/logger/Logger;
# instance fields
.field private final cancelQueriesEnabled:Z
.field private final db:Landroid/database/sqlite/SQLiteDatabase;
.field private final readWrite:Z
# direct methods
.method public static constructor <clinit>()V
.registers 1
.line 1
const-class v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;
invoke-static {v0}, Lcom/j256/ormlite/logger/LoggerFactory;->getLogger(Ljava/lang/Class;)Lcom/j256/ormlite/logger/Logger;
move-result-object v0
sput-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const/4 v0, 0x0
new-array v0, v0, [Ljava/lang/String;
.line 2
sput-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->NO_STRING_ARGS:[Ljava/lang/String;
const-string v0, "VERSION__5.0__"
.line 3
invoke-static {v0}, Lcom/j256/ormlite/misc/VersionUtils;->checkCoreVersusAndroidVersions(Ljava/lang/String;)V
return-void
.end method
.method public constructor <init>(Landroid/database/sqlite/SQLiteDatabase;Z)V
.registers 4
const/4 v0, 0x0
.line 1
invoke-direct {p0, p1, p2, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;-><init>(Landroid/database/sqlite/SQLiteDatabase;ZZ)V
return-void
.end method
.method public constructor <init>(Landroid/database/sqlite/SQLiteDatabase;ZZ)V
.registers 5
.line 2
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 3
iput-object p1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
.line 4
iput-boolean p2, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->readWrite:Z
.line 5
iput-boolean p3, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->cancelQueriesEnabled:Z
.line 6
sget-object p3, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
invoke-static {p2}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object p2
const-string v0, "{}: db {} opened, read-write = {}"
invoke-virtual {p3, v0, p0, p1, p2}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
return-void
.end method
.method private bindArgs(Landroid/database/sqlite/SQLiteStatement;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;)V
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
if-nez p2, :cond_3
return-void
:cond_3
const/4 v0, 0x0
.line 1
:goto_4
array-length v1, p2
if-ge v0, v1, :cond_7c
.line 2
aget-object v1, p2, v0
if-nez v1, :cond_11
add-int/lit8 v1, v0, 0x1
.line 3
invoke-virtual {p1, v1}, Landroid/database/sqlite/SQLiteProgram;->bindNull(I)V
goto :goto_79
.line 4
:cond_11
aget-object v2, p3, v0
invoke-virtual {v2}, Lcom/j256/ormlite/field/FieldType;->getSqlType()Lcom/j256/ormlite/field/SqlType;
move-result-object v2
.line 5
sget-object v3, Lcom/j256/ormlite/android/AndroidDatabaseConnection$1;->$SwitchMap$com$j256$ormlite$field$SqlType:[I
invoke-virtual {v2}, Ljava/lang/Enum;->ordinal()I
move-result v4
aget v3, v3, v4
packed-switch v3, :pswitch_data_7e
.line 6
new-instance p1, Ljava/sql/SQLException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "Unknown sql argument type: "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/sql/SQLException;-><init>(Ljava/lang/String;)V
throw p1
.line 7
:pswitch_39
new-instance p1, Ljava/sql/SQLException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "Invalid Android type: "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/sql/SQLException;-><init>(Ljava/lang/String;)V
throw p1
:pswitch_50
add-int/lit8 v2, v0, 0x1
.line 8
check-cast v1, [B
invoke-virtual {p1, v2, v1}, Landroid/database/sqlite/SQLiteProgram;->bindBlob(I[B)V
goto :goto_79
:pswitch_58
add-int/lit8 v2, v0, 0x1
.line 9
check-cast v1, Ljava/lang/Number;
invoke-virtual {v1}, Ljava/lang/Number;->doubleValue()D
move-result-wide v3
invoke-virtual {p1, v2, v3, v4}, Landroid/database/sqlite/SQLiteProgram;->bindDouble(ID)V
goto :goto_79
:pswitch_64
add-int/lit8 v2, v0, 0x1
.line 10
check-cast v1, Ljava/lang/Number;
invoke-virtual {v1}, Ljava/lang/Number;->longValue()J
move-result-wide v3
invoke-virtual {p1, v2, v3, v4}, Landroid/database/sqlite/SQLiteProgram;->bindLong(IJ)V
goto :goto_79
:pswitch_70
add-int/lit8 v2, v0, 0x1
.line 11
invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {p1, v2, v1}, Landroid/database/sqlite/SQLiteProgram;->bindString(ILjava/lang/String;)V
:goto_79
add-int/lit8 v0, v0, 0x1
goto :goto_4
:cond_7c
return-void
nop
:pswitch_data_7e
.packed-switch 0x1
:pswitch_70
:pswitch_70
:pswitch_70
:pswitch_64
:pswitch_64
:pswitch_64
:pswitch_64
:pswitch_64
:pswitch_58
:pswitch_58
:pswitch_50
:pswitch_50
:pswitch_39
:pswitch_39
:pswitch_39
.end packed-switch
.end method
.method private closeQuietly(Landroid/database/Cursor;)V
.registers 2
if-eqz p1, :cond_5
.line 2
invoke-interface {p1}, Landroid/database/Cursor;->close()V
:cond_5
return-void
.end method
.method private closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
.registers 2
if-eqz p1, :cond_5
.line 3
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteClosable;->close()V
:cond_5
return-void
.end method
.method private toStrings([Ljava/lang/Object;)[Ljava/lang/String;
.registers 6
const/4 v0, 0x0
if-eqz p1, :cond_1f
.line 1
array-length v1, p1
if-nez v1, :cond_7
goto :goto_1f
.line 2
:cond_7
array-length v1, p1
new-array v1, v1, [Ljava/lang/String;
const/4 v2, 0x0
.line 3
:goto_b
array-length v3, p1
if-ge v2, v3, :cond_1e
.line 4
aget-object v3, p1, v2
if-nez v3, :cond_15
.line 5
aput-object v0, v1, v2
goto :goto_1b
.line 6
:cond_15
invoke-virtual {v3}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v3
aput-object v3, v1, v2
:goto_1b
add-int/lit8 v2, v2, 0x1
goto :goto_b
:cond_1e
return-object v1
:cond_1f
:goto_1f
return-object v0
.end method
.method private update(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;Ljava/lang/String;)I
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
const/4 v0, 0x0
.line 2
:try_start_1
iget-object v1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v1, p1}, Landroid/database/sqlite/SQLiteDatabase;->compileStatement(Ljava/lang/String;)Landroid/database/sqlite/SQLiteStatement;
move-result-object v1
:try_end_7
.catch Landroid/database/SQLException; {:try_start_1 .. :try_end_7} :catch_3b
.catchall {:try_start_1 .. :try_end_7} :catchall_39
.line 3
:try_start_7
invoke-direct {p0, v1, p2, p3}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->bindArgs(Landroid/database/sqlite/SQLiteStatement;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;)V
.line 4
invoke-virtual {v1}, Landroid/database/sqlite/SQLiteStatement;->execute()V
:try_end_d
.catch Landroid/database/SQLException; {:try_start_7 .. :try_end_d} :catch_36
.catchall {:try_start_7 .. :try_end_d} :catchall_33
.line 5
invoke-direct {p0, v1}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
.line 6
:try_start_10
iget-object p2, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
const-string p3, "SELECT CHANGES()"
invoke-virtual {p2, p3}, Landroid/database/sqlite/SQLiteDatabase;->compileStatement(Ljava/lang/String;)Landroid/database/sqlite/SQLiteStatement;
move-result-object v0
.line 7
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteStatement;->simpleQueryForLong()J
move-result-wide p2
:try_end_1c
.catch Landroid/database/SQLException; {:try_start_10 .. :try_end_1c} :catch_23
.catchall {:try_start_10 .. :try_end_1c} :catchall_1e
long-to-int p3, p2
goto :goto_24
:catchall_1e
move-exception p1
.line 8
invoke-direct {p0, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
throw p1
:catch_23
const/4 p3, 0x1
:goto_24
invoke-direct {p0, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
.line 9
sget-object p2, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
invoke-static {p3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
const-string v1, "{} statement is compiled and executed, changed {}: {}"
invoke-virtual {p2, v1, p4, v0, p1}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
return p3
:catchall_33
move-exception p1
move-object v0, v1
goto :goto_52
:catch_36
move-exception p2
move-object v0, v1
goto :goto_3c
:catchall_39
move-exception p1
goto :goto_52
:catch_3b
move-exception p2
.line 10
:goto_3c
:try_start_3c
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "updating database failed: "
invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, p2}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
:try_end_52
.catchall {:try_start_3c .. :try_end_52} :catchall_39
.line 11
:goto_52
invoke-direct {p0, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
.line 12
throw p1
.end method
# virtual methods
.method public close()V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 1
:try_start_0
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteClosable;->close()V
.line 2
sget-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v1, "{}: db {} closed"
iget-object v2, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0, v1, p0, v2}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_e
.catch Landroid/database/SQLException; {:try_start_0 .. :try_end_e} :catch_f
return-void
:catch_f
move-exception v0
.line 3
new-instance v1, Ljava/io/IOException;
const-string v2, "problems closing the database connection"
invoke-direct {v1, v2, v0}, Ljava/io/IOException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.end method
.method public closeQuietly()V
.registers 1
.line 1
invoke-static {p0}, Lcom/j256/ormlite/misc/IOUtils;->closeQuietly(Ljava/io/Closeable;)V
return-void
.end method
.method public commit(Ljava/sql/Savepoint;)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
.line 1
:try_start_0
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
.line 2
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
if-nez p1, :cond_14
.line 3
sget-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v1, "{}: transaction is successfuly ended"
invoke-virtual {v0, v1, p0}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;)V
goto :goto_1f
.line 4
:cond_14
sget-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v1, "{}: transaction {} is successfuly ended"
invoke-interface {p1}, Ljava/sql/Savepoint;->getSavepointName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v1, p0, v2}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_1f
.catch Landroid/database/SQLException; {:try_start_0 .. :try_end_1f} :catch_20
:goto_1f
return-void
:catch_20
move-exception v0
if-nez p1, :cond_2a
const-string p1, "problems commiting transaction"
.line 5
invoke-static {p1, v0}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
:cond_2a
const-string v1, "problems commiting transaction "
.line 6
invoke-static {v1}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 7
invoke-interface {p1}, Ljava/sql/Savepoint;->getSavepointName()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, v0}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
.end method
.method public compileStatement(Ljava/lang/String;Lcom/j256/ormlite/stmt/StatementBuilder$StatementType;[Lcom/j256/ormlite/field/FieldType;IZ)Lcom/j256/ormlite/support/CompiledStatement;
.registers 12
.line 1
new-instance p3, Lcom/j256/ormlite/android/AndroidCompiledStatement;
iget-object v2, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
iget-boolean v4, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->cancelQueriesEnabled:Z
move-object v0, p3
move-object v1, p1
move-object v3, p2
move v5, p5
invoke-direct/range {v0 .. v5}, Lcom/j256/ormlite/android/AndroidCompiledStatement;-><init>(Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase;Lcom/j256/ormlite/stmt/StatementBuilder$StatementType;ZZ)V
.line 2
sget-object p2, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string p4, "{}: compiled statement got {}: {}"
invoke-virtual {p2, p4, p0, p3, p1}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
return-object p3
.end method
.method public delete(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;)I
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
const-string v0, "deleted"
invoke-direct {p0, p1, p2, p3, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->update(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;Ljava/lang/String;)I
move-result p1
return p1
.end method
.method public executeStatement(Ljava/lang/String;I)I
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
iget-object p2, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
sget-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->NO_STRING_ARGS:[Ljava/lang/String;
invoke-static {p2, p1, p1, v0}, Lcom/j256/ormlite/android/AndroidCompiledStatement;->execSql(Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)I
move-result p1
return p1
.end method
.method public insert(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;Lcom/j256/ormlite/support/GeneratedKeyHolder;)I
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
const/4 v0, 0x0
.line 1
:try_start_1
iget-object v1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v1, p1}, Landroid/database/sqlite/SQLiteDatabase;->compileStatement(Ljava/lang/String;)Landroid/database/sqlite/SQLiteStatement;
move-result-object v0
.line 2
invoke-direct {p0, v0, p2, p3}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->bindArgs(Landroid/database/sqlite/SQLiteStatement;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;)V
.line 3
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteStatement;->executeInsert()J
move-result-wide p2
if-eqz p4, :cond_17
.line 4
invoke-static {p2, p3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object p2
invoke-interface {p4, p2}, Lcom/j256/ormlite/support/GeneratedKeyHolder;->addKey(Ljava/lang/Number;)V
:cond_17
const/4 p2, 0x1
.line 5
sget-object p3, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string p4, "{}: insert statement is compiled and executed, changed {}: {}"
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
invoke-virtual {p3, p4, p0, v1, p1}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_23
.catch Landroid/database/SQLException; {:try_start_1 .. :try_end_23} :catch_29
.catchall {:try_start_1 .. :try_end_23} :catchall_27
.line 6
invoke-direct {p0, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
return p2
:catchall_27
move-exception p1
goto :goto_40
:catch_29
move-exception p2
.line 7
:try_start_2a
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "inserting to database failed: "
invoke-virtual {p3, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, p2}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
:try_end_40
.catchall {:try_start_2a .. :try_end_40} :catchall_27
.line 8
:goto_40
invoke-direct {p0, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
throw p1
.end method
.method public isAutoCommit()Z
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
.line 1
:try_start_0
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->inTransaction()Z
move-result v0
.line 2
sget-object v1, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v2, "{}: in transaction is {}"
invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v3
invoke-virtual {v1, v2, p0, v3}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_11
.catch Landroid/database/SQLException; {:try_start_0 .. :try_end_11} :catch_14
xor-int/lit8 v0, v0, 0x1
return v0
:catch_14
move-exception v0
const-string v1, "problems getting auto-commit from database"
.line 3
invoke-static {v1, v0}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object v0
throw v0
.end method
.method public isAutoCommitSupported()Z
.registers 2
const/4 v0, 0x1
return v0
.end method
.method public isClosed()Z
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
.line 1
:try_start_0
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->isOpen()Z
move-result v0
.line 2
sget-object v1, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v2, "{}: db {} isOpen returned {}"
iget-object v3, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v4
invoke-virtual {v1, v2, p0, v3, v4}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_13
.catch Landroid/database/SQLException; {:try_start_0 .. :try_end_13} :catch_16
xor-int/lit8 v0, v0, 0x1
return v0
:catch_16
move-exception v0
const-string v1, "problems detecting if the database is closed"
.line 3
invoke-static {v1, v0}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object v0
throw v0
.end method
.method public isReadWrite()Z
.registers 2
iget-boolean v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->readWrite:Z
return v0
.end method
.method public isTableExists(Ljava/lang/String;)Z
.registers 7
.line 1
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "SELECT DISTINCT tbl_name FROM sqlite_master WHERE tbl_name = \'"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "\'"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x0
invoke-virtual {v0, v1, v2}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object v0
.line 2
:try_start_1d
invoke-interface {v0}, Landroid/database/Cursor;->getCount()I
move-result v1
if-lez v1, :cond_25
const/4 v1, 0x1
goto :goto_26
:cond_25
const/4 v1, 0x0
.line 3
:goto_26
sget-object v2, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v3, "{}: isTableExists \'{}\' returned {}"
invoke-static {v1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v4
invoke-virtual {v2, v3, p0, p1, v4}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_31
.catchall {:try_start_1d .. :try_end_31} :catchall_35
.line 4
invoke-interface {v0}, Landroid/database/Cursor;->close()V
return v1
:catchall_35
move-exception p1
invoke-interface {v0}, Landroid/database/Cursor;->close()V
throw p1
.end method
.method public queryForLong(Ljava/lang/String;)J
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
const/4 v0, 0x0
.line 1
:try_start_1
iget-object v1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v1, p1}, Landroid/database/sqlite/SQLiteDatabase;->compileStatement(Ljava/lang/String;)Landroid/database/sqlite/SQLiteStatement;
move-result-object v0
.line 2
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteStatement;->simpleQueryForLong()J
move-result-wide v1
.line 3
sget-object v3, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v4, "{}: query for long simple query returned {}: {}"
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
invoke-virtual {v3, v4, p0, v5, p1}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_16
.catch Landroid/database/SQLException; {:try_start_1 .. :try_end_16} :catch_1c
.catchall {:try_start_1 .. :try_end_16} :catchall_1a
.line 4
invoke-direct {p0, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
return-wide v1
:catchall_1a
move-exception p1
goto :goto_33
:catch_1c
move-exception v1
.line 5
:try_start_1d
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "queryForLong from database failed: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, v1}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
:try_end_33
.catchall {:try_start_1d .. :try_end_33} :catchall_1a
.line 6
:goto_33
invoke-direct {p0, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/sqlite/SQLiteStatement;)V
throw p1
.end method
.method public queryForLong(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;)J
.registers 10
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
const/4 p3, 0x0
.line 7
:try_start_1
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-direct {p0, p2}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->toStrings([Ljava/lang/Object;)[Ljava/lang/String;
move-result-object p2
invoke-virtual {v0, p1, p2}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object p2
:try_end_b
.catch Landroid/database/SQLException; {:try_start_1 .. :try_end_b} :catch_3d
.catchall {:try_start_1 .. :try_end_b} :catchall_3a
.line 8
:try_start_b
new-instance v0, Lcom/j256/ormlite/android/AndroidDatabaseResults;
const/4 v1, 0x0
invoke-direct {v0, p2, p3, v1}, Lcom/j256/ormlite/android/AndroidDatabaseResults;-><init>(Landroid/database/Cursor;Lcom/j256/ormlite/dao/ObjectCache;Z)V
:try_end_11
.catch Landroid/database/SQLException; {:try_start_b .. :try_end_11} :catch_35
.catchall {:try_start_b .. :try_end_11} :catchall_32
.line 9
:try_start_11
invoke-virtual {v0}, Lcom/j256/ormlite/android/AndroidDatabaseResults;->first()Z
move-result p3
if-eqz p3, :cond_1c
.line 10
invoke-virtual {v0, v1}, Lcom/j256/ormlite/android/AndroidDatabaseResults;->getLong(I)J
move-result-wide v1
goto :goto_1e
:cond_1c
const-wide/16 v1, 0x0
.line 11
:goto_1e
sget-object p3, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v3, "{}: query for long raw query returned {}: {}"
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
invoke-virtual {p3, v3, p0, v4, p1}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_29
.catch Landroid/database/SQLException; {:try_start_11 .. :try_end_29} :catch_30
.catchall {:try_start_11 .. :try_end_29} :catchall_57
.line 12
invoke-direct {p0, p2}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/Cursor;)V
.line 13
invoke-static {v0}, Lcom/j256/ormlite/misc/IOUtils;->closeQuietly(Ljava/io/Closeable;)V
return-wide v1
:catch_30
move-exception p3
goto :goto_41
:catchall_32
move-exception p1
move-object v0, p3
goto :goto_58
:catch_35
move-exception v0
move-object v5, v0
move-object v0, p3
move-object p3, v5
goto :goto_41
:catchall_3a
move-exception p1
move-object v0, p3
goto :goto_59
:catch_3d
move-exception p2
move-object v0, p3
move-object p3, p2
move-object p2, v0
.line 14
:goto_41
:try_start_41
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "queryForLong from database failed: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, p3}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
:try_end_57
.catchall {:try_start_41 .. :try_end_57} :catchall_57
:catchall_57
move-exception p1
:goto_58
move-object p3, p2
.line 15
:goto_59
invoke-direct {p0, p3}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/Cursor;)V
.line 16
invoke-static {v0}, Lcom/j256/ormlite/misc/IOUtils;->closeQuietly(Ljava/io/Closeable;)V
throw p1
.end method
.method public queryForOne(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;Lcom/j256/ormlite/stmt/GenericRowMapper;Lcom/j256/ormlite/dao/ObjectCache;)Ljava/lang/Object;
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(",
"Ljava/lang/String;",
"[",
"Ljava/lang/Object;",
"[",
"Lcom/j256/ormlite/field/FieldType;",
"Lcom/j256/ormlite/stmt/GenericRowMapper<",
"TT;>;",
"Lcom/j256/ormlite/dao/ObjectCache;",
")",
"Ljava/lang/Object;"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
const/4 p3, 0x0
.line 1
:try_start_1
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-direct {p0, p2}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->toStrings([Ljava/lang/Object;)[Ljava/lang/String;
move-result-object p2
invoke-virtual {v0, p1, p2}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object p2
:try_end_b
.catch Landroid/database/SQLException; {:try_start_1 .. :try_end_b} :catch_43
.catchall {:try_start_1 .. :try_end_b} :catchall_40
.line 2
:try_start_b
new-instance v0, Lcom/j256/ormlite/android/AndroidDatabaseResults;
const/4 v1, 0x1
invoke-direct {v0, p2, p5, v1}, Lcom/j256/ormlite/android/AndroidDatabaseResults;-><init>(Landroid/database/Cursor;Lcom/j256/ormlite/dao/ObjectCache;Z)V
:try_end_11
.catch Landroid/database/SQLException; {:try_start_b .. :try_end_11} :catch_3c
.catchall {:try_start_b .. :try_end_11} :catchall_3a
.line 3
:try_start_11
sget-object p5, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v1, "{}: queried for one result: {}"
invoke-virtual {p5, v1, p0, p1}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
.line 4
invoke-virtual {v0}, Lcom/j256/ormlite/android/AndroidDatabaseResults;->first()Z
move-result p5
:try_end_1c
.catch Landroid/database/SQLException; {:try_start_11 .. :try_end_1c} :catch_38
.catchall {:try_start_11 .. :try_end_1c} :catchall_5d
if-nez p5, :cond_25
.line 5
:cond_1e
invoke-static {v0}, Lcom/j256/ormlite/misc/IOUtils;->closeQuietly(Ljava/io/Closeable;)V
.line 6
invoke-direct {p0, p2}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/Cursor;)V
return-object p3
.line 7
:cond_25
:try_start_25
invoke-interface {p4, v0}, Lcom/j256/ormlite/stmt/GenericRowMapper;->mapRow(Lcom/j256/ormlite/support/DatabaseResults;)Ljava/lang/Object;
move-result-object p3
.line 8
invoke-virtual {v0}, Lcom/j256/ormlite/android/AndroidDatabaseResults;->next()Z
move-result p4
if-eqz p4, :cond_1e
.line 9
sget-object p1, Lcom/j256/ormlite/support/DatabaseConnection;->MORE_THAN_ONE:Ljava/lang/Object;
:try_end_31
.catch Landroid/database/SQLException; {:try_start_25 .. :try_end_31} :catch_38
.catchall {:try_start_25 .. :try_end_31} :catchall_5d
.line 10
invoke-static {v0}, Lcom/j256/ormlite/misc/IOUtils;->closeQuietly(Ljava/io/Closeable;)V
.line 11
invoke-direct {p0, p2}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/Cursor;)V
return-object p1
:catch_38
move-exception p3
goto :goto_47
:catchall_3a
move-exception p1
goto :goto_5f
:catch_3c
move-exception p4
move-object v0, p3
move-object p3, p4
goto :goto_47
:catchall_40
move-exception p1
move-object p2, p3
goto :goto_5f
:catch_43
move-exception p2
move-object v0, p3
move-object p3, p2
move-object p2, v0
.line 12
:goto_47
:try_start_47
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4}, Ljava/lang/StringBuilder;-><init>()V
const-string p5, "queryForOne from database failed: "
invoke-virtual {p4, p5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, p3}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
:try_end_5d
.catchall {:try_start_47 .. :try_end_5d} :catchall_5d
:catchall_5d
move-exception p1
move-object p3, v0
.line 13
:goto_5f
invoke-static {p3}, Lcom/j256/ormlite/misc/IOUtils;->closeQuietly(Ljava/io/Closeable;)V
.line 14
invoke-direct {p0, p2}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->closeQuietly(Landroid/database/Cursor;)V
throw p1
.end method
.method public rollback(Ljava/sql/Savepoint;)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
.line 1
:try_start_0
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
if-nez p1, :cond_f
.line 2
sget-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v1, "{}: transaction is ended, unsuccessfuly"
invoke-virtual {v0, v1, p0}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;)V
goto :goto_1a
.line 3
:cond_f
sget-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v1, "{}: transaction {} is ended, unsuccessfuly"
invoke-interface {p1}, Ljava/sql/Savepoint;->getSavepointName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v1, p0, v2}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
:try_end_1a
.catch Landroid/database/SQLException; {:try_start_0 .. :try_end_1a} :catch_1b
:goto_1a
return-void
:catch_1b
move-exception v0
if-nez p1, :cond_25
const-string p1, "problems rolling back transaction"
.line 4
invoke-static {p1, v0}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
:cond_25
const-string v1, "problems rolling back transaction "
.line 5
invoke-static {v1}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 6
invoke-interface {p1}, Ljava/sql/Savepoint;->getSavepointName()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, v0}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
.end method
.method public setAutoCommit(Z)V
.registers 2
if-eqz p1, :cond_15
.line 1
iget-object p1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->inTransaction()Z
move-result p1
if-eqz p1, :cond_22
.line 2
iget-object p1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
.line 3
iget-object p1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
goto :goto_22
.line 4
:cond_15
iget-object p1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->inTransaction()Z
move-result p1
if-nez p1, :cond_22
.line 5
iget-object p1, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
:cond_22
:goto_22
return-void
.end method
.method public setSavePoint(Ljava/lang/String;)Ljava/sql/Savepoint;
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
.line 1
:try_start_0
iget-object v0, p0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
.line 2
sget-object v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->logger:Lcom/j256/ormlite/logger/Logger;
const-string v1, "{}: save-point set with name {}"
invoke-virtual {v0, v1, p0, p1}, Lcom/j256/ormlite/logger/Logger;->trace(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
.line 3
new-instance v0, Lcom/j256/ormlite/android/AndroidDatabaseConnection$OurSavePoint;
invoke-direct {v0, p1}, Lcom/j256/ormlite/android/AndroidDatabaseConnection$OurSavePoint;-><init>(Ljava/lang/String;)V
:try_end_11
.catch Landroid/database/SQLException; {:try_start_0 .. :try_end_11} :catch_12
return-object v0
:catch_12
move-exception v0
.line 4
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "problems beginning transaction "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p1, v0}, Lcom/j256/ormlite/misc/SqlExceptionUtil;->create(Ljava/lang/String;Ljava/lang/Throwable;)Ljava/sql/SQLException;
move-result-object p1
throw p1
.end method
.method public toString()Ljava/lang/String;
.registers 3
.line 1
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "@"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-super {p0}, Ljava/lang/Object;->hashCode()I
move-result v1
.line 2
invoke-static {v1, v0}, Landroidx/appcompat/q;->d(ILjava/lang/StringBuilder;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public update(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;)I
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/sql/SQLException;
}
.end annotation
const-string v0, "updated"
.line 1
invoke-direct {p0, p1, p2, p3, v0}, Lcom/j256/ormlite/android/AndroidDatabaseConnection;->update(Ljava/lang/String;[Ljava/lang/Object;[Lcom/j256/ormlite/field/FieldType;Ljava/lang/String;)I
move-result p1
return p1
.end method