public final class org.h2.fulltext.FullText$FullTextTrigger implements org.h2.api.Trigger
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: org.h2.fulltext.FullText$FullTextTrigger
super_class: java.lang.Object
{
private org.h2.fulltext.FullTextSettings setting;
descriptor: Lorg/h2/fulltext/FullTextSettings;
flags: (0x0002) ACC_PRIVATE
private org.h2.fulltext.IndexInfo index;
descriptor: Lorg/h2/fulltext/IndexInfo;
flags: (0x0002) ACC_PRIVATE
private int[] columnTypes;
descriptor: [I
flags: (0x0002) ACC_PRIVATE
private final java.sql.PreparedStatement[] prepStatements;
descriptor: [Ljava/sql/PreparedStatement;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private boolean useOwnConnection;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private static final int INSERT_WORD;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 0
private static final int INSERT_ROW;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 1
private static final int INSERT_MAP;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 2
private static final int DELETE_ROW;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 3
private static final int DELETE_MAP;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 4
private static final int SELECT_ROW;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 5
private static final java.lang.String[] SQL;
descriptor: [Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=4, locals=0, args_size=0
0: bipush 6
anewarray java.lang.String
dup
iconst_0
1: ldc "MERGE INTO FT.WORDS(NAME) KEY(NAME) VALUES(?)"
aastore
dup
iconst_1
2: ldc "INSERT INTO FT.ROWS(HASH, INDEXID, KEY) VALUES(?, ?, ?)"
aastore
dup
iconst_2
3: ldc "INSERT INTO FT.MAP(ROWID, WORDID) VALUES(?, ?)"
aastore
dup
iconst_3
4: ldc "DELETE FROM FT.ROWS WHERE HASH=? AND INDEXID=? AND KEY=?"
aastore
dup
iconst_4
5: ldc "DELETE FROM FT.MAP WHERE ROWID=? AND WORDID=?"
aastore
dup
iconst_5
6: ldc "SELECT ID FROM FT.ROWS WHERE HASH=? AND INDEXID=? AND KEY=?"
aastore
7: putstatic org.h2.fulltext.FullText$FullTextTrigger.SQL:[Ljava/lang/String;
8: 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
getstatic org.h2.fulltext.FullText$FullTextTrigger.SQL:[Ljava/lang/String;
arraylength
anewarray java.sql.PreparedStatement
putfield org.h2.fulltext.FullText$FullTextTrigger.prepStatements:[Ljava/sql/PreparedStatement;
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
public void init(java.sql.Connection, java.lang.String, java.lang.String, java.lang.String, boolean, int);
descriptor: (Ljava/sql/Connection;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;ZI)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=14, 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
invokestatic org.h2.fulltext.FullTextSettings.getInstance:(Ljava/sql/Connection;)Lorg/h2/fulltext/FullTextSettings;
putfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
1: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
invokevirtual org.h2.fulltext.FullTextSettings.isInitialized:()Z
ifne 3
2: aload 1
invokestatic org.h2.fulltext.FullText.init:(Ljava/sql/Connection;)V
3: StackMap locals:
StackMap stack:
invokestatic org.h2.util.Utils.newSmallArrayList:()Ljava/util/ArrayList;
astore 7
start local 7 4: aload 1
invokeinterface java.sql.Connection.getMetaData:()Ljava/sql/DatabaseMetaData;
astore 8
start local 8 5: aload 8
aconst_null
6: aload 2
invokestatic org.h2.util.StringUtils.escapeMetaDataPattern:(Ljava/lang/String;)Ljava/lang/String;
7: aload 4
invokestatic org.h2.util.StringUtils.escapeMetaDataPattern:(Ljava/lang/String;)Ljava/lang/String;
8: aconst_null
9: invokeinterface java.sql.DatabaseMetaData.getColumns:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/sql/ResultSet;
astore 9
start local 9 10: invokestatic org.h2.util.Utils.newSmallArrayList:()Ljava/util/ArrayList;
astore 10
start local 10 11: goto 13
12: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.String java.lang.String java.lang.String int int java.util.ArrayList java.sql.DatabaseMetaData java.sql.ResultSet java.util.ArrayList
StackMap stack:
aload 10
aload 9
ldc "COLUMN_NAME"
invokeinterface java.sql.ResultSet.getString:(Ljava/lang/String;)Ljava/lang/String;
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
13: StackMap locals:
StackMap stack:
aload 9
invokeinterface java.sql.ResultSet.next:()Z
ifne 12
14: aload 0
aload 10
invokevirtual java.util.ArrayList.size:()I
newarray 10
putfield org.h2.fulltext.FullText$FullTextTrigger.columnTypes:[I
15: aload 0
new org.h2.fulltext.IndexInfo
dup
invokespecial org.h2.fulltext.IndexInfo.<init>:()V
putfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
16: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
aload 2
putfield org.h2.fulltext.IndexInfo.schema:Ljava/lang/String;
17: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
aload 4
putfield org.h2.fulltext.IndexInfo.table:Ljava/lang/String;
18: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
aload 10
iconst_0
anewarray java.lang.String
invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
checkcast java.lang.String[]
putfield org.h2.fulltext.IndexInfo.columns:[Ljava/lang/String;
19: aload 8
aconst_null
20: aload 2
invokestatic org.h2.util.StringUtils.escapeMetaDataPattern:(Ljava/lang/String;)Ljava/lang/String;
21: aload 4
invokestatic org.h2.util.StringUtils.escapeMetaDataPattern:(Ljava/lang/String;)Ljava/lang/String;
22: aconst_null
23: invokeinterface java.sql.DatabaseMetaData.getColumns:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/sql/ResultSet;
astore 9
24: iconst_0
istore 11
start local 11 25: goto 28
26: StackMap locals: int
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.columnTypes:[I
iload 11
aload 9
ldc "DATA_TYPE"
invokeinterface java.sql.ResultSet.getInt:(Ljava/lang/String;)I
iastore
27: iinc 11 1
StackMap locals:
StackMap stack:
28: aload 9
invokeinterface java.sql.ResultSet.next:()Z
ifne 26
end local 11 29: aload 7
invokevirtual java.util.ArrayList.isEmpty:()Z
ifeq 37
30: aload 8
aconst_null
31: aload 2
invokestatic org.h2.util.StringUtils.escapeMetaDataPattern:(Ljava/lang/String;)Ljava/lang/String;
32: aload 4
33: invokeinterface java.sql.DatabaseMetaData.getPrimaryKeys:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/sql/ResultSet;
astore 9
34: goto 36
35: StackMap locals:
StackMap stack:
aload 7
aload 9
ldc "COLUMN_NAME"
invokeinterface java.sql.ResultSet.getString:(Ljava/lang/String;)Ljava/lang/String;
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
36: StackMap locals:
StackMap stack:
aload 9
invokeinterface java.sql.ResultSet.next:()Z
ifne 35
37: StackMap locals:
StackMap stack:
aload 7
invokevirtual java.util.ArrayList.isEmpty:()Z
ifeq 39
38: new java.lang.StringBuilder
dup
ldc "No primary key for table "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokestatic org.h2.fulltext.FullText.throwException:(Ljava/lang/String;)Ljava/sql/SQLException;
athrow
39: StackMap locals:
StackMap stack:
invokestatic org.h2.util.Utils.newSmallArrayList:()Ljava/util/ArrayList;
astore 11
start local 11 40: aload 1
41: ldc "SELECT ID, COLUMNS FROM FT.INDEXES WHERE SCHEMA=? AND `TABLE`=?"
42: invokeinterface java.sql.Connection.prepareStatement:(Ljava/lang/String;)Ljava/sql/PreparedStatement;
astore 12
start local 12 43: aload 12
iconst_1
aload 2
invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
44: aload 12
iconst_2
aload 4
invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
45: aload 12
invokeinterface java.sql.PreparedStatement.executeQuery:()Ljava/sql/ResultSet;
astore 9
46: aload 9
invokeinterface java.sql.ResultSet.next:()Z
ifeq 51
47: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
aload 9
iconst_1
invokeinterface java.sql.ResultSet.getInt:(I)I
putfield org.h2.fulltext.IndexInfo.id:I
48: aload 9
iconst_2
invokeinterface java.sql.ResultSet.getString:(I)Ljava/lang/String;
astore 13
start local 13 49: aload 13
ifnull 51
50: aload 11
aload 13
bipush 44
iconst_1
invokestatic org.h2.util.StringUtils.arraySplit:(Ljava/lang/String;CZ)[Ljava/lang/String;
invokestatic java.util.Collections.addAll:(Ljava/util/Collection;[Ljava/lang/Object;)Z
pop
end local 13 51: StackMap locals: java.util.ArrayList java.sql.PreparedStatement
StackMap stack:
aload 11
invokevirtual java.util.ArrayList.isEmpty:()Z
ifeq 53
52: aload 11
aload 10
invokevirtual java.util.ArrayList.addAll:(Ljava/util/Collection;)Z
pop
53: StackMap locals:
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
aload 7
invokevirtual java.util.ArrayList.size:()I
newarray 10
putfield org.h2.fulltext.IndexInfo.keys:[I
54: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.keys:[I
aload 7
aload 10
invokestatic org.h2.fulltext.FullText.setColumns:([ILjava/util/ArrayList;Ljava/util/ArrayList;)V
55: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
aload 11
invokevirtual java.util.ArrayList.size:()I
newarray 10
putfield org.h2.fulltext.IndexInfo.indexColumns:[I
56: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.indexColumns:[I
aload 11
aload 10
invokestatic org.h2.fulltext.FullText.setColumns:([ILjava/util/ArrayList;Ljava/util/ArrayList;)V
57: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
invokevirtual org.h2.fulltext.FullTextSettings.addIndexInfo:(Lorg/h2/fulltext/IndexInfo;)V
58: aload 0
aload 1
invokestatic org.h2.fulltext.FullText$FullTextTrigger.isMultiThread:(Ljava/sql/Connection;)Z
putfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
59: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifne 67
60: iconst_0
istore 13
start local 13 61: goto 66
62: StackMap locals: int
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.prepStatements:[Ljava/sql/PreparedStatement;
iload 13
aload 1
getstatic org.h2.fulltext.FullText$FullTextTrigger.SQL:[Ljava/lang/String;
iload 13
aaload
63: iconst_1
64: invokeinterface java.sql.Connection.prepareStatement:(Ljava/lang/String;I)Ljava/sql/PreparedStatement;
aastore
65: iinc 13 1
StackMap locals:
StackMap stack:
66: iload 13
getstatic org.h2.fulltext.FullText$FullTextTrigger.SQL:[Ljava/lang/String;
arraylength
if_icmplt 62
end local 13 67: StackMap locals:
StackMap stack:
return
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 68 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
0 68 1 conn Ljava/sql/Connection;
0 68 2 schemaName Ljava/lang/String;
0 68 3 triggerName Ljava/lang/String;
0 68 4 tableName Ljava/lang/String;
0 68 5 before Z
0 68 6 type I
4 68 7 keyList Ljava/util/ArrayList<Ljava/lang/String;>;
5 68 8 meta Ljava/sql/DatabaseMetaData;
10 68 9 rs Ljava/sql/ResultSet;
11 68 10 columnList Ljava/util/ArrayList<Ljava/lang/String;>;
25 29 11 i I
40 68 11 indexList Ljava/util/ArrayList<Ljava/lang/String;>;
43 68 12 prep Ljava/sql/PreparedStatement;
49 51 13 columns Ljava/lang/String;
61 67 13 i I
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
conn
schemaName
triggerName
tableName
before
type
static boolean isMultiThread(java.sql.Connection);
descriptor: (Ljava/sql/Connection;)Z
flags: (0x0008) ACC_STATIC
Code:
stack=3, locals=5, args_size=1
start local 0 0: aconst_null
astore 1
aconst_null
astore 2
1: aload 0
invokeinterface java.sql.Connection.createStatement:()Ljava/sql/Statement;
astore 3
start local 3 2: aload 3
3: ldc "SELECT value FROM information_schema.settings WHERE name = 'MULTI_THREADED'"
4: invokeinterface java.sql.Statement.executeQuery:(Ljava/lang/String;)Ljava/sql/ResultSet;
astore 4
start local 4 5: aload 4
invokeinterface java.sql.ResultSet.next:()Z
ifeq 6
ldc "0"
aload 4
iconst_1
invokeinterface java.sql.ResultSet.getString:(I)Ljava/lang/String;
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifne 6
iconst_1
goto 7
StackMap locals: java.sql.Connection java.lang.Throwable java.lang.Throwable java.sql.Statement java.sql.ResultSet
StackMap stack:
6: iconst_0
7: StackMap locals:
StackMap stack: int
aload 3
ifnull 8
aload 3
invokeinterface java.sql.Statement.close:()V
8: StackMap locals:
StackMap stack: int
ireturn
end local 4 StackMap locals: java.sql.Connection java.lang.Throwable java.lang.Throwable java.sql.Statement
StackMap stack: java.lang.Throwable
9: astore 1
10: aload 3
ifnull 11
aload 3
invokeinterface java.sql.Statement.close:()V
end local 3 StackMap locals:
StackMap stack:
11: aload 1
athrow
StackMap locals:
StackMap stack: java.lang.Throwable
12: astore 2
aload 1
ifnonnull 13
aload 2
astore 1
goto 14
StackMap locals:
StackMap stack:
13: aload 1
aload 2
if_acmpeq 14
aload 1
aload 2
invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
StackMap locals:
StackMap stack:
14: aload 1
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 conn Ljava/sql/Connection;
2 11 3 stat Ljava/sql/Statement;
5 9 4 rs Ljava/sql/ResultSet;
Exception table:
from to target type
2 7 9 any
1 8 12 any
9 12 12 any
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
conn
public void fire(java.sql.Connection, java.lang.Object[], java.lang.Object[]);
descriptor: (Ljava/sql/Connection;[Ljava/lang/Object;[Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 2
ifnull 8
1: aload 3
ifnull 6
2: aload 2
aload 3
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.indexColumns:[I
invokestatic org.h2.fulltext.FullText.hasChanged:([Ljava/lang/Object;[Ljava/lang/Object;[I)Z
ifeq 10
3: aload 0
aload 1
aload 2
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.delete:(Ljava/sql/Connection;[Ljava/lang/Object;)V
4: aload 0
aload 1
aload 3
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.insert:(Ljava/sql/Connection;[Ljava/lang/Object;)V
5: goto 10
6: StackMap locals:
StackMap stack:
aload 0
aload 1
aload 2
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.delete:(Ljava/sql/Connection;[Ljava/lang/Object;)V
7: goto 10
StackMap locals:
StackMap stack:
8: aload 3
ifnull 10
9: aload 0
aload 1
aload 3
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.insert:(Ljava/sql/Connection;[Ljava/lang/Object;)V
10: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
0 11 1 conn Ljava/sql/Connection;
0 11 2 oldRow [Ljava/lang/Object;
0 11 3 newRow [Ljava/lang/Object;
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
conn
oldRow
newRow
public void close();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
invokevirtual org.h2.fulltext.FullTextSettings.removeIndexInfo:(Lorg/h2/fulltext/IndexInfo;)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
public void remove();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
invokevirtual org.h2.fulltext.FullTextSettings.removeIndexInfo:(Lorg/h2/fulltext/IndexInfo;)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
protected void insert(java.sql.Connection, java.lang.Object[]);
descriptor: (Ljava/sql/Connection;[Ljava/lang/Object;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=15, args_size=3
start local 0 start local 1 start local 2 0: aconst_null
astore 3
start local 3 1: aconst_null
astore 4
start local 4 2: aload 0
aload 2
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getKey:([Ljava/lang/Object;)Ljava/lang/String;
astore 5
start local 5 3: aload 5
invokevirtual java.lang.String.hashCode:()I
istore 6
start local 6 4: aload 0
aload 1
iconst_1
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getStatement:(Ljava/sql/Connection;I)Ljava/sql/PreparedStatement;
astore 3
5: aload 3
iconst_1
iload 6
invokeinterface java.sql.PreparedStatement.setInt:(II)V
6: aload 3
iconst_2
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.id:I
invokeinterface java.sql.PreparedStatement.setInt:(II)V
7: aload 3
iconst_3
aload 5
invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
8: aload 3
invokeinterface java.sql.PreparedStatement.execute:()Z
pop
9: aload 3
invokeinterface java.sql.PreparedStatement.getGeneratedKeys:()Ljava/sql/ResultSet;
astore 7
start local 7 10: aload 7
invokeinterface java.sql.ResultSet.next:()Z
pop
11: aload 7
iconst_1
invokeinterface java.sql.ResultSet.getInt:(I)I
istore 8
start local 8 12: aload 0
aload 1
iconst_2
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getStatement:(Ljava/sql/Connection;I)Ljava/sql/PreparedStatement;
astore 4
13: aload 4
iconst_1
iload 8
invokeinterface java.sql.PreparedStatement.setInt:(II)V
14: aload 0
aload 1
aload 2
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getWordIds:(Ljava/sql/Connection;[Ljava/lang/Object;)[I
astore 9
start local 9 15: aload 9
dup
astore 13
arraylength
istore 12
iconst_0
istore 11
goto 20
StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement java.lang.String int java.sql.ResultSet int int[] top int int int[]
StackMap stack:
16: aload 13
iload 11
iaload
istore 10
start local 10 17: aload 4
iconst_2
iload 10
invokeinterface java.sql.PreparedStatement.setInt:(II)V
18: aload 4
invokeinterface java.sql.PreparedStatement.execute:()Z
pop
end local 10 19: iinc 11 1
StackMap locals:
StackMap stack:
20: iload 11
iload 12
if_icmplt 16
end local 9 end local 8 end local 7 end local 6 end local 5 21: goto 27
StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement
StackMap stack: java.lang.Throwable
22: astore 14
23: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifeq 26
24: aload 3
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
25: aload 4
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
26: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement top top top top top top top top top java.lang.Throwable
StackMap stack:
aload 14
athrow
27: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifeq 30
28: aload 3
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
29: aload 4
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
30: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 31 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
0 31 1 conn Ljava/sql/Connection;
0 31 2 row [Ljava/lang/Object;
1 31 3 prepInsertRow Ljava/sql/PreparedStatement;
2 31 4 prepInsertMap Ljava/sql/PreparedStatement;
3 21 5 key Ljava/lang/String;
4 21 6 hash I
10 21 7 rs Ljava/sql/ResultSet;
12 21 8 rowId I
15 21 9 wordIds [I
17 19 10 id I
Exception table:
from to target type
2 22 22 any
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
conn
row
protected void delete(java.sql.Connection, java.lang.Object[]);
descriptor: (Ljava/sql/Connection;[Ljava/lang/Object;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=16, args_size=3
start local 0 start local 1 start local 2 0: aconst_null
astore 3
start local 3 1: aconst_null
astore 4
start local 4 2: aconst_null
astore 5
start local 5 3: aload 0
aload 2
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getKey:([Ljava/lang/Object;)Ljava/lang/String;
astore 6
start local 6 4: aload 6
invokevirtual java.lang.String.hashCode:()I
istore 7
start local 7 5: aload 0
aload 1
iconst_5
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getStatement:(Ljava/sql/Connection;I)Ljava/sql/PreparedStatement;
astore 3
6: aload 3
iconst_1
iload 7
invokeinterface java.sql.PreparedStatement.setInt:(II)V
7: aload 3
iconst_2
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.id:I
invokeinterface java.sql.PreparedStatement.setInt:(II)V
8: aload 3
iconst_3
aload 6
invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
9: aload 3
invokeinterface java.sql.PreparedStatement.executeQuery:()Ljava/sql/ResultSet;
astore 8
start local 8 10: aload 0
aload 1
iconst_4
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getStatement:(Ljava/sql/Connection;I)Ljava/sql/PreparedStatement;
astore 4
11: aload 0
aload 1
iconst_3
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getStatement:(Ljava/sql/Connection;I)Ljava/sql/PreparedStatement;
astore 5
12: aload 8
invokeinterface java.sql.ResultSet.next:()Z
ifeq 33
13: aload 8
iconst_1
invokeinterface java.sql.ResultSet.getInt:(I)I
istore 9
start local 9 14: aload 4
iconst_1
iload 9
invokeinterface java.sql.PreparedStatement.setInt:(II)V
15: aload 0
aload 1
aload 2
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getWordIds:(Ljava/sql/Connection;[Ljava/lang/Object;)[I
astore 10
start local 10 16: aload 10
dup
astore 14
arraylength
istore 13
iconst_0
istore 12
goto 21
StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement java.sql.PreparedStatement java.lang.String int java.sql.ResultSet int int[] top int int int[]
StackMap stack:
17: aload 14
iload 12
iaload
istore 11
start local 11 18: aload 4
iconst_2
iload 11
invokeinterface java.sql.PreparedStatement.setInt:(II)V
19: aload 4
invokeinterface java.sql.PreparedStatement.executeUpdate:()I
pop
end local 11 20: iinc 12 1
StackMap locals:
StackMap stack:
21: iload 12
iload 13
if_icmplt 17
22: aload 5
iconst_1
iload 7
invokeinterface java.sql.PreparedStatement.setInt:(II)V
23: aload 5
iconst_2
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.id:I
invokeinterface java.sql.PreparedStatement.setInt:(II)V
24: aload 5
iconst_3
aload 6
invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
25: aload 5
invokeinterface java.sql.PreparedStatement.executeUpdate:()I
pop
end local 10 end local 9 end local 8 end local 7 end local 6 26: goto 33
StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement java.sql.PreparedStatement
StackMap stack: java.lang.Throwable
27: astore 15
28: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifeq 32
29: aload 3
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
30: aload 4
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
31: aload 5
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
32: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement java.sql.PreparedStatement top top top top top top top top top java.lang.Throwable
StackMap stack:
aload 15
athrow
33: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.sql.PreparedStatement java.sql.PreparedStatement java.sql.PreparedStatement
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifeq 37
34: aload 3
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
35: aload 4
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
36: aload 5
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
37: StackMap locals:
StackMap stack:
return
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 38 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
0 38 1 conn Ljava/sql/Connection;
0 38 2 row [Ljava/lang/Object;
1 38 3 prepSelectRow Ljava/sql/PreparedStatement;
2 38 4 prepDeleteMap Ljava/sql/PreparedStatement;
3 38 5 prepDeleteRow Ljava/sql/PreparedStatement;
4 26 6 key Ljava/lang/String;
5 26 7 hash I
10 26 8 rs Ljava/sql/ResultSet;
14 26 9 rowId I
16 26 10 wordIds [I
18 20 11 id I
Exception table:
from to target type
3 27 27 any
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
conn
row
private int[] getWordIds(java.sql.Connection, java.lang.Object[]);
descriptor: (Ljava/sql/Connection;[Ljava/lang/Object;)[I
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=14, args_size=3
start local 0 start local 1 start local 2 0: new java.util.HashSet
dup
invokespecial java.util.HashSet.<init>:()V
astore 3
start local 3 1: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.indexColumns:[I
dup
astore 7
arraylength
istore 6
iconst_0
istore 5
goto 15
StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet top int int int[]
StackMap stack:
2: aload 7
iload 5
iaload
istore 4
start local 4 3: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.columnTypes:[I
iload 4
iaload
istore 8
start local 8 4: aload 2
iload 4
aaload
astore 9
start local 9 5: iload 8
sipush 2005
if_icmpne 12
aload 9
ifnull 12
6: aload 9
instanceof java.io.Reader
ifeq 9
7: aload 9
checkcast java.io.Reader
astore 10
start local 10 8: goto 10
end local 10 9: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet int int int int[] int java.lang.Object
StackMap stack:
aload 9
checkcast java.sql.Clob
invokeinterface java.sql.Clob.getCharacterStream:()Ljava/io/Reader;
astore 10
start local 10 10: StackMap locals: java.io.Reader
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
aload 3
aload 10
invokestatic org.h2.fulltext.FullText.addWords:(Lorg/h2/fulltext/FullTextSettings;Ljava/util/Set;Ljava/io/Reader;)V
end local 10 11: goto 14
12: StackMap locals:
StackMap stack:
aload 9
iload 8
invokestatic org.h2.fulltext.FullText.asString:(Ljava/lang/Object;I)Ljava/lang/String;
astore 10
start local 10 13: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
aload 3
aload 10
invokestatic org.h2.fulltext.FullText.addWords:(Lorg/h2/fulltext/FullTextSettings;Ljava/util/Set;Ljava/lang/String;)V
end local 10 end local 9 end local 8 end local 4 14: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet top int int int[]
StackMap stack:
iinc 5 1
StackMap locals:
StackMap stack:
15: iload 5
iload 6
if_icmplt 2
16: aconst_null
astore 4
start local 4 17: aload 0
aload 1
iconst_0
invokevirtual org.h2.fulltext.FullText$FullTextTrigger.getStatement:(Ljava/sql/Connection;I)Ljava/sql/PreparedStatement;
astore 4
18: aload 3
invokevirtual java.util.HashSet.size:()I
newarray 10
astore 5
start local 5 19: iconst_0
istore 6
start local 6 20: aload 3
invokevirtual java.util.HashSet.iterator:()Ljava/util/Iterator;
astore 8
goto 35
StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement int[] int top java.util.Iterator
StackMap stack:
21: aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 7
start local 7 22: goto 32
start local 10 23: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement int[] int java.lang.String java.util.Iterator top java.lang.Integer
StackMap stack:
aload 4
iconst_1
aload 7
invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
24: aload 4
invokeinterface java.sql.PreparedStatement.execute:()Z
pop
25: aload 4
invokeinterface java.sql.PreparedStatement.getGeneratedKeys:()Ljava/sql/ResultSet;
astore 11
start local 11 26: aload 11
invokeinterface java.sql.ResultSet.next:()Z
ifeq 32
27: aload 11
iconst_1
invokeinterface java.sql.ResultSet.getInt:(I)I
istore 9
start local 9 28: iload 9
ifeq 32
29: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
aload 7
iload 9
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual org.h2.fulltext.FullTextSettings.addWord:(Ljava/lang/String;Ljava/lang/Integer;)V
30: iload 9
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
astore 10
31: goto 34
end local 11 end local 10 end local 9 32: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement int[] int java.lang.String java.util.Iterator
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.setting:Lorg/h2/fulltext/FullTextSettings;
aload 7
invokevirtual org.h2.fulltext.FullTextSettings.getWordId:(Ljava/lang/String;)Ljava/lang/Integer;
dup
astore 10
start local 10 33: ifnull 23
34: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement int[] int java.lang.String java.util.Iterator top java.lang.Integer
StackMap stack:
aload 5
iload 6
iinc 6 1
aload 10
invokevirtual java.lang.Integer.intValue:()I
iastore
end local 10 end local 7 35: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement int[] int top java.util.Iterator
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 21
36: aload 5
invokestatic java.util.Arrays.sort:([I)V
37: aload 5
astore 13
38: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifeq 40
39: aload 4
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
40: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement int[] int top top top top top top int[]
StackMap stack:
aload 13
areturn
end local 6 end local 5 41: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement
StackMap stack: java.lang.Throwable
astore 12
42: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifeq 44
43: aload 4
invokestatic org.h2.util.IOUtils.closeSilently:(Ljava/lang/AutoCloseable;)V
44: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.sql.Connection java.lang.Object[] java.util.HashSet java.sql.PreparedStatement top top top top top top top java.lang.Throwable
StackMap stack:
aload 12
athrow
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 45 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
0 45 1 conn Ljava/sql/Connection;
0 45 2 row [Ljava/lang/Object;
1 45 3 words Ljava/util/HashSet<Ljava/lang/String;>;
3 14 4 idx I
4 14 8 type I
5 14 9 data Ljava/lang/Object;
8 9 10 reader Ljava/io/Reader;
10 11 10 reader Ljava/io/Reader;
13 14 10 string Ljava/lang/String;
17 45 4 prepInsertWord Ljava/sql/PreparedStatement;
19 41 5 wordIds [I
20 41 6 i I
22 35 7 word Ljava/lang/String;
28 32 9 wordId I
23 32 10 wId Ljava/lang/Integer;
33 35 10 wId Ljava/lang/Integer;
26 32 11 rs Ljava/sql/ResultSet;
Exception table:
from to target type
17 38 41 any
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
conn
row
private java.lang.String getKey(java.lang.Object[]);
descriptor: ([Ljava/lang/Object;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=8, args_size=2
start local 0 start local 1 0: new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 2
start local 2 1: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.keys:[I
astore 3
start local 3 2: iconst_0
istore 4
start local 4 3: aload 3
arraylength
istore 5
start local 5 4: goto 15
5: StackMap locals: org.h2.fulltext.FullText$FullTextTrigger java.lang.Object[] java.lang.StringBuilder int[] int int
StackMap stack:
iload 4
ifle 7
6: aload 2
ldc " AND "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
7: StackMap locals:
StackMap stack:
aload 3
iload 4
iaload
istore 6
start local 6 8: aload 2
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.index:Lorg/h2/fulltext/IndexInfo;
getfield org.h2.fulltext.IndexInfo.columns:[Ljava/lang/String;
iload 6
aaload
invokestatic org.h2.util.StringUtils.quoteIdentifier:(Ljava/lang/StringBuilder;Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
9: aload 1
iload 6
aaload
astore 7
start local 7 10: aload 7
ifnonnull 13
11: aload 2
ldc " IS NULL"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
12: goto 14
13: StackMap locals: int java.lang.Object
StackMap stack:
aload 2
bipush 61
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
aload 7
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.columnTypes:[I
iload 6
iaload
invokestatic org.h2.fulltext.FullText.quoteSQL:(Ljava/lang/Object;I)Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 7 end local 6 14: StackMap locals:
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
15: iload 4
iload 5
if_icmplt 5
end local 5 end local 4 16: 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 17 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
0 17 1 row [Ljava/lang/Object;
1 17 2 builder Ljava/lang/StringBuilder;
2 17 3 keys [I
3 16 4 i I
4 16 5 l I
8 14 6 columnIndex I
10 14 7 o Ljava/lang/Object;
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
row
private java.sql.PreparedStatement getStatement(java.sql.Connection, int);
descriptor: (Ljava/sql/Connection;I)Ljava/sql/PreparedStatement;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.useOwnConnection:Z
ifeq 2
1: aload 1
getstatic org.h2.fulltext.FullText$FullTextTrigger.SQL:[Ljava/lang/String;
iload 2
aaload
iconst_1
invokeinterface java.sql.Connection.prepareStatement:(Ljava/lang/String;I)Ljava/sql/PreparedStatement;
goto 3
2: StackMap locals:
StackMap stack:
aload 0
getfield org.h2.fulltext.FullText$FullTextTrigger.prepStatements:[Ljava/sql/PreparedStatement;
iload 2
aaload
3: StackMap locals:
StackMap stack: java.sql.PreparedStatement
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/h2/fulltext/FullText$FullTextTrigger;
0 4 1 conn Ljava/sql/Connection;
0 4 2 index I
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
conn
index
}
SourceFile: "FullText.java"
NestHost: org.h2.fulltext.FullText
InnerClasses:
public final FullTextTrigger = org.h2.fulltext.FullText$FullTextTrigger of org.h2.fulltext.FullText