public class android.database.sqlite.SQLiteQueryBuilder
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: android.database.sqlite.SQLiteQueryBuilder
super_class: java.lang.Object
{
private static final java.lang.String TAG;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "SQLiteQueryBuilder"
private static final java.util.regex.Pattern sLimitPattern;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private java.util.Map<java.lang.String, java.lang.String> mProjectionMap;
descriptor: Ljava/util/Map;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
private java.lang.String mTables;
descriptor: Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
private java.lang.StringBuilder mWhereClause;
descriptor: Ljava/lang/StringBuilder;
flags: (0x0002) ACC_PRIVATE
private boolean mDistinct;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private android.database.sqlite.SQLiteDatabase$CursorFactory mFactory;
descriptor: Landroid/database/sqlite/SQLiteDatabase$CursorFactory;
flags: (0x0002) ACC_PRIVATE
private boolean mStrict;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc "\\s*\\d+\\s*(,\\s*\\d+\\s*)?"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
1: putstatic android.database.sqlite.SQLiteQueryBuilder.sLimitPattern:Ljava/util/regex/Pattern;
2: return
LocalVariableTable:
Start End Slot Name Signature
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aconst_null
putfield android.database.sqlite.SQLiteQueryBuilder.mProjectionMap:Ljava/util/Map;
2: aload 0
ldc ""
putfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
3: aload 0
aconst_null
putfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
4: aload 0
iconst_0
putfield android.database.sqlite.SQLiteQueryBuilder.mDistinct:Z
5: aload 0
aconst_null
putfield android.database.sqlite.SQLiteQueryBuilder.mFactory:Landroid/database/sqlite/SQLiteDatabase$CursorFactory;
6: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
public void setDistinct(boolean);
descriptor: (Z)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield android.database.sqlite.SQLiteQueryBuilder.mDistinct:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 2 1 distinct Z
MethodParameters:
Name Flags
distinct
public java.lang.String getTables();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
public void setTables(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 2 1 inTables Ljava/lang/String;
MethodParameters:
Name Flags
inTables
public void appendWhere(java.lang.CharSequence);
descriptor: (Ljava/lang/CharSequence;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
ifnonnull 2
1: aload 0
new java.lang.StringBuilder
dup
aload 1
invokeinterface java.lang.CharSequence.length:()I
bipush 16
iadd
invokespecial java.lang.StringBuilder.<init>:(I)V
putfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
2: StackMap locals:
StackMap stack:
aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;)Ljava/lang/StringBuilder;
pop
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 4 1 inWhere Ljava/lang/CharSequence;
MethodParameters:
Name Flags
inWhere
public void appendWhereEscapeString(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
ifnonnull 2
1: aload 0
new java.lang.StringBuilder
dup
aload 1
invokevirtual java.lang.String.length:()I
bipush 16
iadd
invokespecial java.lang.StringBuilder.<init>:(I)V
putfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
2: StackMap locals:
StackMap stack:
aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
aload 1
invokestatic android.database.DatabaseUtils.appendEscapedSQLString:(Ljava/lang/StringBuilder;Ljava/lang/String;)V
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 4 1 inWhere Ljava/lang/String;
MethodParameters:
Name Flags
inWhere
public void setProjectionMap(java.util.Map<java.lang.String, java.lang.String>);
descriptor: (Ljava/util/Map;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield android.database.sqlite.SQLiteQueryBuilder.mProjectionMap:Ljava/util/Map;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 2 1 columnMap Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
Signature: (Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;)V
MethodParameters:
Name Flags
columnMap
public void setCursorFactory(android.database.sqlite.SQLiteDatabase$CursorFactory);
descriptor: (Landroid/database/sqlite/SQLiteDatabase$CursorFactory;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield android.database.sqlite.SQLiteQueryBuilder.mFactory:Landroid/database/sqlite/SQLiteDatabase$CursorFactory;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 2 1 factory Landroid/database/sqlite/SQLiteDatabase$CursorFactory;
MethodParameters:
Name Flags
factory
public void setStrict(boolean);
descriptor: (Z)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield android.database.sqlite.SQLiteQueryBuilder.mStrict:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 2 1 flag Z
MethodParameters:
Name Flags
flag
public static java.lang.String buildQueryString(boolean, java.lang.String, java.lang.String[], java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String);
descriptor: (ZLjava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=5, locals=9, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: aload 4
invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
ifeq 4
aload 5
invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
ifne 4
1: new java.lang.IllegalArgumentException
dup
2: ldc "HAVING clauses are only permitted when using a groupBy clause"
3: invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals:
StackMap stack:
aload 7
invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
ifne 6
getstatic android.database.sqlite.SQLiteQueryBuilder.sLimitPattern:Ljava/util/regex/Pattern;
aload 7
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
invokevirtual java.util.regex.Matcher.matches:()Z
ifne 6
5: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
ldc "invalid LIMIT clauses:"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 7
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
6: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
bipush 120
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 8
start local 8 7: aload 8
ldc "SELECT "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
8: iload 0
ifeq 10
9: aload 8
ldc "DISTINCT "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
10: StackMap locals: java.lang.StringBuilder
StackMap stack:
aload 2
ifnull 13
aload 2
arraylength
ifeq 13
11: aload 8
aload 2
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendColumns:(Ljava/lang/StringBuilder;[Ljava/lang/String;)V
12: goto 14
13: StackMap locals:
StackMap stack:
aload 8
ldc "* "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
14: StackMap locals:
StackMap stack:
aload 8
ldc "FROM "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
15: aload 8
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
16: aload 8
ldc " WHERE "
aload 3
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
17: aload 8
ldc " GROUP BY "
aload 4
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
18: aload 8
ldc " HAVING "
aload 5
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
19: aload 8
ldc " ORDER BY "
aload 6
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
20: aload 8
ldc " LIMIT "
aload 7
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
21: aload 8
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 22 0 distinct Z
0 22 1 tables Ljava/lang/String;
0 22 2 columns [Ljava/lang/String;
0 22 3 where Ljava/lang/String;
0 22 4 groupBy Ljava/lang/String;
0 22 5 having Ljava/lang/String;
0 22 6 orderBy Ljava/lang/String;
0 22 7 limit Ljava/lang/String;
7 22 8 query Ljava/lang/StringBuilder;
MethodParameters:
Name Flags
distinct
tables
columns
where
groupBy
having
orderBy
limit
private static void appendClause(java.lang.StringBuilder, java.lang.String, java.lang.String);
descriptor: (Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 2
invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
ifne 3
1: aload 0
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
2: aload 0
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
3: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 s Ljava/lang/StringBuilder;
0 4 1 name Ljava/lang/String;
0 4 2 clause Ljava/lang/String;
MethodParameters:
Name Flags
s
name
clause
public static void appendColumns(java.lang.StringBuilder, java.lang.String[]);
descriptor: (Ljava/lang/StringBuilder;[Ljava/lang/String;)V
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=5, args_size=2
start local 0 start local 1 0: aload 1
arraylength
istore 2
start local 2 1: iconst_0
istore 3
start local 3 2: goto 9
3: StackMap locals: int int
StackMap stack:
aload 1
iload 3
aaload
astore 4
start local 4 4: aload 4
ifnull 8
5: iload 3
ifle 7
6: aload 0
ldc ", "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
7: StackMap locals: java.lang.String
StackMap stack:
aload 0
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 4 8: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
9: iload 3
iload 2
if_icmplt 3
end local 3 10: aload 0
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
11: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 s Ljava/lang/StringBuilder;
0 12 1 columns [Ljava/lang/String;
1 12 2 n I
2 10 3 i I
4 8 4 column Ljava/lang/String;
MethodParameters:
Name Flags
s
columns
public android.database.Cursor query(android.database.sqlite.SQLiteDatabase, java.lang.String[], java.lang.String, java.lang.String[], java.lang.String, java.lang.String, java.lang.String);
descriptor: (Landroid/database/sqlite/SQLiteDatabase;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Landroid/database/Cursor;
flags: (0x0001) ACC_PUBLIC
Code:
stack=10, locals=8, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: aload 0
aload 1
aload 2
aload 3
aload 4
aload 5
aload 6
aload 7
1: aconst_null
aconst_null
2: invokevirtual android.database.sqlite.SQLiteQueryBuilder.query:(Landroid/database/sqlite/SQLiteDatabase;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Landroid/os/CancellationSignal;)Landroid/database/Cursor;
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 3 1 db Landroid/database/sqlite/SQLiteDatabase;
0 3 2 projectionIn [Ljava/lang/String;
0 3 3 selection Ljava/lang/String;
0 3 4 selectionArgs [Ljava/lang/String;
0 3 5 groupBy Ljava/lang/String;
0 3 6 having Ljava/lang/String;
0 3 7 sortOrder Ljava/lang/String;
MethodParameters:
Name Flags
db
projectionIn
selection
selectionArgs
groupBy
having
sortOrder
public android.database.Cursor query(android.database.sqlite.SQLiteDatabase, java.lang.String[], java.lang.String, java.lang.String[], java.lang.String, java.lang.String, java.lang.String, java.lang.String);
descriptor: (Landroid/database/sqlite/SQLiteDatabase;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Landroid/database/Cursor;
flags: (0x0001) ACC_PUBLIC
Code:
stack=10, locals=9, args_size=9
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 0: aload 0
aload 1
aload 2
aload 3
aload 4
1: aload 5
aload 6
aload 7
aload 8
aconst_null
2: invokevirtual android.database.sqlite.SQLiteQueryBuilder.query:(Landroid/database/sqlite/SQLiteDatabase;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Landroid/os/CancellationSignal;)Landroid/database/Cursor;
areturn
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 3 1 db Landroid/database/sqlite/SQLiteDatabase;
0 3 2 projectionIn [Ljava/lang/String;
0 3 3 selection Ljava/lang/String;
0 3 4 selectionArgs [Ljava/lang/String;
0 3 5 groupBy Ljava/lang/String;
0 3 6 having Ljava/lang/String;
0 3 7 sortOrder Ljava/lang/String;
0 3 8 limit Ljava/lang/String;
MethodParameters:
Name Flags
db
projectionIn
selection
selectionArgs
groupBy
having
sortOrder
limit
public android.database.Cursor query(android.database.sqlite.SQLiteDatabase, java.lang.String[], java.lang.String, java.lang.String[], java.lang.String, java.lang.String, java.lang.String, java.lang.String, android.os.CancellationSignal);
descriptor: (Landroid/database/sqlite/SQLiteDatabase;[Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Landroid/os/CancellationSignal;)Landroid/database/Cursor;
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=13, args_size=10
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 0: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
ifnonnull 2
1: aconst_null
areturn
2: StackMap locals:
StackMap stack:
aload 0
3: aload 2
aload 3
aload 5
aload 6
4: aload 7
aload 8
5: invokevirtual android.database.sqlite.SQLiteQueryBuilder.buildQuery:([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
astore 11
start local 11 6: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mStrict:Z
ifeq 13
aload 3
ifnull 13
aload 3
invokevirtual java.lang.String.length:()I
ifle 13
7: aload 1
aload 11
aload 9
invokevirtual android.database.sqlite.SQLiteDatabase.validateSql:(Ljava/lang/String;Landroid/os/CancellationSignal;)V
8: aload 0
aload 2
aload 0
aload 3
invokevirtual android.database.sqlite.SQLiteQueryBuilder.wrap:(Ljava/lang/String;)Ljava/lang/String;
aload 5
9: aload 6
aload 7
aload 8
10: invokevirtual android.database.sqlite.SQLiteQueryBuilder.buildQuery:([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
astore 12
start local 12 11: aload 12
astore 10
end local 12 start local 10 12: goto 14
end local 10 13: StackMap locals: android.database.sqlite.SQLiteQueryBuilder android.database.sqlite.SQLiteDatabase java.lang.String[] java.lang.String java.lang.String[] java.lang.String java.lang.String java.lang.String java.lang.String android.os.CancellationSignal top java.lang.String
StackMap stack:
aload 11
astore 10
start local 10 14: StackMap locals: android.database.sqlite.SQLiteQueryBuilder android.database.sqlite.SQLiteDatabase java.lang.String[] java.lang.String java.lang.String[] java.lang.String java.lang.String java.lang.String java.lang.String android.os.CancellationSignal java.lang.String java.lang.String
StackMap stack:
aload 4
astore 12
start local 12 15: ldc "SQLiteQueryBuilder"
iconst_3
invokestatic android.util.Log.isLoggable:(Ljava/lang/String;I)Z
ifeq 20
16: getstatic android.os.Build.IS_DEBUGGABLE:Z
ifeq 19
17: ldc "SQLiteQueryBuilder"
new java.lang.StringBuilder
dup
aload 10
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc " with args "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 12
invokestatic java.util.Arrays.toString:([Ljava/lang/Object;)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokestatic android.util.Log.d:(Ljava/lang/String;Ljava/lang/String;)I
pop
18: goto 20
19: StackMap locals: java.lang.String[]
StackMap stack:
ldc "SQLiteQueryBuilder"
aload 10
invokestatic android.util.Log.d:(Ljava/lang/String;Ljava/lang/String;)I
pop
20: StackMap locals:
StackMap stack:
aload 1
21: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mFactory:Landroid/database/sqlite/SQLiteDatabase$CursorFactory;
aload 10
aload 12
22: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
invokestatic android.database.sqlite.SQLiteDatabase.findEditTable:(Ljava/lang/String;)Ljava/lang/String;
23: aload 9
24: invokevirtual android.database.sqlite.SQLiteDatabase.rawQueryWithFactory:(Landroid/database/sqlite/SQLiteDatabase$CursorFactory;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Landroid/os/CancellationSignal;)Landroid/database/Cursor;
areturn
end local 12 end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 25 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 25 1 db Landroid/database/sqlite/SQLiteDatabase;
0 25 2 projectionIn [Ljava/lang/String;
0 25 3 selection Ljava/lang/String;
0 25 4 selectionArgs [Ljava/lang/String;
0 25 5 groupBy Ljava/lang/String;
0 25 6 having Ljava/lang/String;
0 25 7 sortOrder Ljava/lang/String;
0 25 8 limit Ljava/lang/String;
0 25 9 cancellationSignal Landroid/os/CancellationSignal;
12 13 10 sql Ljava/lang/String;
14 25 10 sql Ljava/lang/String;
6 25 11 unwrappedSql Ljava/lang/String;
11 12 12 wrappedSql Ljava/lang/String;
15 25 12 sqlArgs [Ljava/lang/String;
MethodParameters:
Name Flags
db
projectionIn
selection
selectionArgs
groupBy
having
sortOrder
limit
cancellationSignal
public int update(android.database.sqlite.SQLiteDatabase, android.content.ContentValues, java.lang.String, java.lang.String[]);
descriptor: (Landroid/database/sqlite/SQLiteDatabase;Landroid/content/ContentValues;Ljava/lang/String;[Ljava/lang/String;)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=5, args_size=5
start local 0 0: new java.lang.Error
dup
ldc "Unresolved compilation problems: \n\tEmptyArray cannot be resolved to a variable\n\tEmptyArray cannot be resolved to a variable\n"
invokespecial java.lang.Error.<init>:(Ljava/lang/String;)V
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
MethodParameters:
Name Flags
db
values
selection
selectionArgs
public int delete(android.database.sqlite.SQLiteDatabase, java.lang.String, java.lang.String[]);
descriptor: (Landroid/database/sqlite/SQLiteDatabase;Ljava/lang/String;[Ljava/lang/String;)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=7, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
ldc "No tables defined"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
pop
1: aload 1
ldc "No database defined"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
pop
2: aload 0
aload 2
invokevirtual android.database.sqlite.SQLiteQueryBuilder.buildDelete:(Ljava/lang/String;)Ljava/lang/String;
astore 5
start local 5 3: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mStrict:Z
ifeq 8
4: aload 1
aload 5
aconst_null
invokevirtual android.database.sqlite.SQLiteDatabase.validateSql:(Ljava/lang/String;Landroid/os/CancellationSignal;)V
5: aload 0
aload 0
aload 2
invokevirtual android.database.sqlite.SQLiteQueryBuilder.wrap:(Ljava/lang/String;)Ljava/lang/String;
invokevirtual android.database.sqlite.SQLiteQueryBuilder.buildDelete:(Ljava/lang/String;)Ljava/lang/String;
astore 6
start local 6 6: aload 6
astore 4
end local 6 start local 4 7: goto 9
end local 4 8: StackMap locals: android.database.sqlite.SQLiteQueryBuilder android.database.sqlite.SQLiteDatabase java.lang.String java.lang.String[] top java.lang.String
StackMap stack:
aload 5
astore 4
start local 4 9: StackMap locals: android.database.sqlite.SQLiteQueryBuilder android.database.sqlite.SQLiteDatabase java.lang.String java.lang.String[] java.lang.String java.lang.String
StackMap stack:
aload 3
astore 6
start local 6 10: ldc "SQLiteQueryBuilder"
iconst_3
invokestatic android.util.Log.isLoggable:(Ljava/lang/String;I)Z
ifeq 15
11: getstatic android.os.Build.IS_DEBUGGABLE:Z
ifeq 14
12: ldc "SQLiteQueryBuilder"
new java.lang.StringBuilder
dup
aload 4
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc " with args "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 6
invokestatic java.util.Arrays.toString:([Ljava/lang/Object;)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokestatic android.util.Log.d:(Ljava/lang/String;Ljava/lang/String;)I
pop
13: goto 15
14: StackMap locals: java.lang.String[]
StackMap stack:
ldc "SQLiteQueryBuilder"
aload 4
invokestatic android.util.Log.d:(Ljava/lang/String;Ljava/lang/String;)I
pop
15: StackMap locals:
StackMap stack:
aload 1
aload 4
aload 6
invokevirtual android.database.sqlite.SQLiteDatabase.executeSql:(Ljava/lang/String;[Ljava/lang/Object;)I
ireturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 16 1 db Landroid/database/sqlite/SQLiteDatabase;
0 16 2 selection Ljava/lang/String;
0 16 3 selectionArgs [Ljava/lang/String;
7 8 4 sql Ljava/lang/String;
9 16 4 sql Ljava/lang/String;
3 16 5 unwrappedSql Ljava/lang/String;
6 7 6 wrappedSql Ljava/lang/String;
10 16 6 sqlArgs [Ljava/lang/String;
MethodParameters:
Name Flags
db
selection
selectionArgs
public java.lang.String buildQuery(java.lang.String[], java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String);
descriptor: ([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=9, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 0
aload 1
invokevirtual android.database.sqlite.SQLiteQueryBuilder.computeProjection:([Ljava/lang/String;)[Ljava/lang/String;
astore 7
start local 7 1: aload 0
aload 2
invokevirtual android.database.sqlite.SQLiteQueryBuilder.computeWhere:(Ljava/lang/String;)Ljava/lang/String;
astore 8
start local 8 2: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mDistinct:Z
aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
aload 7
aload 8
3: aload 3
aload 4
aload 5
aload 6
4: invokestatic android.database.sqlite.SQLiteQueryBuilder.buildQueryString:(ZLjava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
areturn
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 5 1 projectionIn [Ljava/lang/String;
0 5 2 selection Ljava/lang/String;
0 5 3 groupBy Ljava/lang/String;
0 5 4 having Ljava/lang/String;
0 5 5 sortOrder Ljava/lang/String;
0 5 6 limit Ljava/lang/String;
1 5 7 projection [Ljava/lang/String;
2 5 8 where Ljava/lang/String;
MethodParameters:
Name Flags
projectionIn
selection
groupBy
having
sortOrder
limit
public java.lang.String buildQuery(java.lang.String[], java.lang.String, java.lang.String[], java.lang.String, java.lang.String, java.lang.String, java.lang.String);
descriptor: ([Ljava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=8, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: aload 0
aload 1
aload 2
aload 4
aload 5
aload 6
aload 7
invokevirtual android.database.sqlite.SQLiteQueryBuilder.buildQuery:([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 1 1 projectionIn [Ljava/lang/String;
0 1 2 selection Ljava/lang/String;
0 1 3 selectionArgs [Ljava/lang/String;
0 1 4 groupBy Ljava/lang/String;
0 1 5 having Ljava/lang/String;
0 1 6 sortOrder Ljava/lang/String;
0 1 7 limit Ljava/lang/String;
RuntimeVisibleAnnotations:
java.lang.Deprecated()
MethodParameters:
Name Flags
projectionIn
selection
selectionArgs
groupBy
having
sortOrder
limit
public java.lang.String buildUpdate(android.content.ContentValues, java.lang.String);
descriptor: (Landroid/content/ContentValues;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 0: new java.lang.Error
dup
ldc "Unresolved compilation problem: \n\tEmptyArray cannot be resolved to a variable\n"
invokespecial java.lang.Error.<init>:(Ljava/lang/String;)V
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
MethodParameters:
Name Flags
values
selection
public java.lang.String buildDelete(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: new java.lang.StringBuilder
dup
bipush 120
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 2
start local 2 1: aload 2
ldc "DELETE FROM "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
2: aload 2
aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mTables:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
3: aload 0
aload 1
invokevirtual android.database.sqlite.SQLiteQueryBuilder.computeWhere:(Ljava/lang/String;)Ljava/lang/String;
astore 3
start local 3 4: aload 2
ldc " WHERE "
aload 3
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
5: aload 2
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 6 1 selection Ljava/lang/String;
1 6 2 sql Ljava/lang/StringBuilder;
4 6 3 where Ljava/lang/String;
MethodParameters:
Name Flags
selection
public java.lang.String buildUnionSubQuery(java.lang.String, java.lang.String[], java.util.Set<java.lang.String>, int, java.lang.String, java.lang.String, java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;[Ljava/lang/String;Ljava/util/Set;ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=13, args_size=9
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 0: aload 2
arraylength
istore 9
start local 9 1: iload 9
anewarray java.lang.String
astore 10
start local 10 2: iconst_0
istore 11
start local 11 3: goto 16
4: StackMap locals: int java.lang.String[] int
StackMap stack:
aload 2
iload 11
aaload
astore 12
start local 12 5: aload 12
aload 1
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifeq 10
6: aload 10
iload 11
new java.lang.StringBuilder
dup
ldc "'"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 5
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "' AS "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
7: aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
8: aastore
9: goto 15
StackMap locals: java.lang.String
StackMap stack:
10: iload 11
iload 4
if_icmple 12
11: aload 3
aload 12
invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
ifeq 14
12: StackMap locals:
StackMap stack:
aload 10
iload 11
aload 12
aastore
13: goto 15
14: StackMap locals:
StackMap stack:
aload 10
iload 11
new java.lang.StringBuilder
dup
ldc "NULL AS "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 12
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
aastore
end local 12 15: StackMap locals:
StackMap stack:
iinc 11 1
StackMap locals:
StackMap stack:
16: iload 11
iload 9
if_icmplt 4
end local 11 17: aload 0
18: aload 10
aload 6
aload 7
aload 8
19: aconst_null
20: aconst_null
21: invokevirtual android.database.sqlite.SQLiteQueryBuilder.buildQuery:([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
areturn
end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 22 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 22 1 typeDiscriminatorColumn Ljava/lang/String;
0 22 2 unionColumns [Ljava/lang/String;
0 22 3 columnsPresentInTable Ljava/util/Set<Ljava/lang/String;>;
0 22 4 computedColumnsOffset I
0 22 5 typeDiscriminatorValue Ljava/lang/String;
0 22 6 selection Ljava/lang/String;
0 22 7 groupBy Ljava/lang/String;
0 22 8 having Ljava/lang/String;
1 22 9 unionColumnsCount I
2 22 10 projectionIn [Ljava/lang/String;
3 17 11 i I
5 15 12 unionColumn Ljava/lang/String;
Signature: (Ljava/lang/String;[Ljava/lang/String;Ljava/util/Set<Ljava/lang/String;>;ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
MethodParameters:
Name Flags
typeDiscriminatorColumn
unionColumns
columnsPresentInTable
computedColumnsOffset
typeDiscriminatorValue
selection
groupBy
having
public java.lang.String buildUnionSubQuery(java.lang.String, java.lang.String[], java.util.Set<java.lang.String>, int, java.lang.String, java.lang.String, java.lang.String[], java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;[Ljava/lang/String;Ljava/util/Set;ILjava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=9, locals=10, args_size=10
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 0: aload 0
1: aload 1
aload 2
aload 3
2: iload 4
aload 5
aload 6
3: aload 8
aload 9
4: invokevirtual android.database.sqlite.SQLiteQueryBuilder.buildUnionSubQuery:(Ljava/lang/String;[Ljava/lang/String;Ljava/util/Set;ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
areturn
end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 5 1 typeDiscriminatorColumn Ljava/lang/String;
0 5 2 unionColumns [Ljava/lang/String;
0 5 3 columnsPresentInTable Ljava/util/Set<Ljava/lang/String;>;
0 5 4 computedColumnsOffset I
0 5 5 typeDiscriminatorValue Ljava/lang/String;
0 5 6 selection Ljava/lang/String;
0 5 7 selectionArgs [Ljava/lang/String;
0 5 8 groupBy Ljava/lang/String;
0 5 9 having Ljava/lang/String;
Signature: (Ljava/lang/String;[Ljava/lang/String;Ljava/util/Set<Ljava/lang/String;>;ILjava/lang/String;Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
RuntimeVisibleAnnotations:
java.lang.Deprecated()
MethodParameters:
Name Flags
typeDiscriminatorColumn
unionColumns
columnsPresentInTable
computedColumnsOffset
typeDiscriminatorValue
selection
selectionArgs
groupBy
having
public java.lang.String buildUnionQuery(java.lang.String[], java.lang.String, java.lang.String);
descriptor: ([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=8, args_size=4
start local 0 start local 1 start local 2 start local 3 0: new java.lang.StringBuilder
dup
sipush 128
invokespecial java.lang.StringBuilder.<init>:(I)V
astore 4
start local 4 1: aload 1
arraylength
istore 5
start local 5 2: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mDistinct:Z
ifeq 3
ldc " UNION "
goto 4
StackMap locals: java.lang.StringBuilder int
StackMap stack:
3: ldc " UNION ALL "
StackMap locals:
StackMap stack: java.lang.String
4: astore 6
start local 6 5: iconst_0
istore 7
start local 7 6: goto 11
7: StackMap locals: java.lang.String int
StackMap stack:
iload 7
ifle 9
8: aload 4
aload 6
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
9: StackMap locals:
StackMap stack:
aload 4
aload 1
iload 7
aaload
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
10: iinc 7 1
StackMap locals:
StackMap stack:
11: iload 7
iload 5
if_icmplt 7
end local 7 12: aload 4
ldc " ORDER BY "
aload 2
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
13: aload 4
ldc " LIMIT "
aload 3
invokestatic android.database.sqlite.SQLiteQueryBuilder.appendClause:(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)V
14: aload 4
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 15 1 subQueries [Ljava/lang/String;
0 15 2 sortOrder Ljava/lang/String;
0 15 3 limit Ljava/lang/String;
1 15 4 query Ljava/lang/StringBuilder;
2 15 5 subQueryCount I
5 15 6 unionOperator Ljava/lang/String;
6 12 7 i I
MethodParameters:
Name Flags
subQueries
sortOrder
limit
private java.lang.String[] computeProjection(java.lang.String[]);
descriptor: ([Ljava/lang/String;)[Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=7, args_size=2
start local 0 start local 1 0: aload 1
ifnull 22
aload 1
arraylength
ifle 22
1: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mProjectionMap:Ljava/util/Map;
ifnull 21
2: aload 1
arraylength
anewarray java.lang.String
astore 2
start local 2 3: aload 1
arraylength
istore 3
start local 3 4: iconst_0
istore 4
start local 4 5: goto 19
6: StackMap locals: java.lang.String[] int int
StackMap stack:
aload 1
iload 4
aaload
astore 5
start local 5 7: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mProjectionMap:Ljava/util/Map;
aload 5
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.String
astore 6
start local 6 8: aload 6
ifnull 11
9: aload 2
iload 4
aload 6
aastore
10: goto 18
11: StackMap locals: java.lang.String java.lang.String
StackMap stack:
aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mStrict:Z
ifne 15
12: aload 5
ldc " AS "
invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
ifne 13
aload 5
ldc " as "
invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
ifeq 15
13: StackMap locals:
StackMap stack:
aload 2
iload 4
aload 5
aastore
14: goto 18
15: StackMap locals:
StackMap stack:
new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
ldc "Invalid column "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
16: aload 1
iload 4
aaload
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
17: invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
end local 6 end local 5 18: StackMap locals:
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
19: iload 4
iload 3
if_icmplt 6
end local 4 20: aload 2
areturn
end local 3 end local 2 21: StackMap locals:
StackMap stack:
aload 1
areturn
22: StackMap locals:
StackMap stack:
aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mProjectionMap:Ljava/util/Map;
ifnull 34
23: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mProjectionMap:Ljava/util/Map;
invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
astore 2
start local 2 24: aload 2
invokeinterface java.util.Set.size:()I
anewarray java.lang.String
astore 3
start local 3 25: aload 2
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 4
start local 4 26: iconst_0
istore 5
start local 5 27: goto 32
28: StackMap locals: android.database.sqlite.SQLiteQueryBuilder java.lang.String[] java.util.Set java.lang.String[] java.util.Iterator int
StackMap stack:
aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.Map$Entry
astore 6
start local 6 29: aload 6
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
checkcast java.lang.String
ldc "_count"
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifeq 31
30: goto 32
31: StackMap locals: java.util.Map$Entry
StackMap stack:
aload 3
iload 5
iinc 5 1
aload 6
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast java.lang.String
aastore
end local 6 32: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 28
33: aload 3
areturn
end local 5 end local 4 end local 3 end local 2 34: StackMap locals: android.database.sqlite.SQLiteQueryBuilder java.lang.String[]
StackMap stack:
aconst_null
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 35 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 35 1 projectionIn [Ljava/lang/String;
3 21 2 projection [Ljava/lang/String;
4 21 3 length I
5 20 4 i I
7 18 5 userColumn Ljava/lang/String;
8 18 6 column Ljava/lang/String;
24 34 2 entrySet Ljava/util/Set<Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;>;
25 34 3 projection [Ljava/lang/String;
26 34 4 entryIter Ljava/util/Iterator<Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;>;
27 34 5 i I
29 32 6 entry Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;
MethodParameters:
Name Flags
projectionIn
private java.lang.String computeWhere(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=5, args_size=2
start local 0 start local 1 0: aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
ifeq 1
iconst_0
goto 2
StackMap locals:
StackMap stack:
1: iconst_1
StackMap locals:
StackMap stack: int
2: istore 2
start local 2 3: aload 1
invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
ifeq 4
iconst_0
goto 5
StackMap locals: int
StackMap stack:
4: iconst_1
StackMap locals:
StackMap stack: int
5: istore 3
start local 3 6: iload 2
ifne 7
iload 3
ifeq 15
7: StackMap locals: int
StackMap stack:
new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 4
start local 4 8: iload 2
ifeq 10
9: aload 4
bipush 40
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
aload 0
getfield android.database.sqlite.SQLiteQueryBuilder.mWhereClause:Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/CharSequence;)Ljava/lang/StringBuilder;
bipush 41
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
10: StackMap locals: java.lang.StringBuilder
StackMap stack:
iload 2
ifeq 12
iload 3
ifeq 12
11: aload 4
ldc " AND "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
12: StackMap locals:
StackMap stack:
iload 3
ifeq 14
13: aload 4
bipush 40
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
bipush 41
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
pop
14: StackMap locals:
StackMap stack:
aload 4
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 4 15: StackMap locals:
StackMap stack:
aconst_null
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 16 1 selection Ljava/lang/String;
3 16 2 hasInternal Z
6 16 3 hasExternal Z
8 15 4 where Ljava/lang/StringBuilder;
MethodParameters:
Name Flags
selection
private java.lang.String wrap(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokestatic android.text.TextUtils.isEmpty:(Ljava/lang/CharSequence;)Z
ifeq 2
1: aload 1
areturn
2: StackMap locals:
StackMap stack:
new java.lang.StringBuilder
dup
ldc "("
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ")"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Landroid/database/sqlite/SQLiteQueryBuilder;
0 3 1 arg Ljava/lang/String;
MethodParameters:
Name Flags
arg
}
SourceFile: "SQLiteQueryBuilder.java"
InnerClasses:
public abstract CursorFactory = android.database.sqlite.SQLiteDatabase$CursorFactory of android.database.sqlite.SQLiteDatabase
public abstract Entry = java.util.Map$Entry of java.util.Map