public class org.hibernate.dialect.pagination.SQLServer2005LimitHandler extends org.hibernate.dialect.pagination.AbstractLimitHandler
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.hibernate.dialect.pagination.SQLServer2005LimitHandler
super_class: org.hibernate.dialect.pagination.AbstractLimitHandler
{
private static final java.lang.String SELECT;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "select"
private static final java.lang.String SELECT_WITH_SPACE;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "select "
private static final java.lang.String FROM;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "from"
private static final java.lang.String DISTINCT;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "distinct"
private static final java.lang.String ORDER_BY;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "order by"
private static final java.util.regex.Pattern ALIAS_PATTERN;
descriptor: Ljava/util/regex/Pattern;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private boolean topAdded;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private boolean hasOffset;
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 "(?i)\\sas\\s(.)+$"
invokestatic java.util.regex.Pattern.compile:(Ljava/lang/String;)Ljava/util/regex/Pattern;
putstatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.ALIAS_PATTERN:Ljava/util/regex/Pattern;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(java.lang.String, org.hibernate.engine.spi.RowSelection);
descriptor: (Ljava/lang/String;Lorg/hibernate/engine/spi/RowSelection;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
aload 2
invokespecial org.hibernate.dialect.pagination.AbstractLimitHandler.<init>:(Ljava/lang/String;Lorg/hibernate/engine/spi/RowSelection;)V
1: aload 0
iconst_1
putfield org.hibernate.dialect.pagination.SQLServer2005LimitHandler.hasOffset:Z
2: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 3 1 sql Ljava/lang/String;
0 3 2 selection Lorg/hibernate/engine/spi/RowSelection;
MethodParameters:
Name Flags
sql
selection
public boolean supportsLimit();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
public boolean useMaxForLimit();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
public boolean supportsLimitOffset();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
public boolean supportsVariableLimit();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
public int convertToFirstRowValue(int);
descriptor: (I)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: iload 1
iconst_1
iadd
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 1 1 zeroBasedFirstResult I
MethodParameters:
Name Flags
zeroBasedFirstResult
public java.lang.String getProcessedSql();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=1
start local 0 0: new java.lang.StringBuilder
dup
aload 0
getfield org.hibernate.dialect.pagination.SQLServer2005LimitHandler.sql:Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
astore 1
start local 1 1: aload 1
aload 1
invokevirtual java.lang.StringBuilder.length:()I
iconst_1
isub
invokevirtual java.lang.StringBuilder.charAt:(I)C
bipush 59
if_icmpne 3
2: aload 1
aload 1
invokevirtual java.lang.StringBuilder.length:()I
iconst_1
isub
invokevirtual java.lang.StringBuilder.setLength:(I)V
3: StackMap locals: java.lang.StringBuilder
StackMap stack:
aload 0
getfield org.hibernate.dialect.pagination.SQLServer2005LimitHandler.selection:Lorg/hibernate/engine/spi/RowSelection;
invokestatic org.hibernate.dialect.pagination.LimitHelper.hasFirstRow:(Lorg/hibernate/engine/spi/RowSelection;)Z
ifeq 12
4: aload 0
aload 1
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.fillAliasInSelectClause:(Ljava/lang/StringBuilder;)Ljava/lang/String;
astore 2
start local 2 5: aload 1
ldc "order by"
iconst_0
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOfWord:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 3
start local 3 6: iload 3
ifle 8
7: aload 0
aload 1
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.addTopExpression:(Ljava/lang/StringBuilder;)V
8: StackMap locals: java.lang.String int
StackMap stack:
aload 0
aload 1
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.encloseWithOuterQuery:(Ljava/lang/StringBuilder;)V
9: aload 1
iconst_0
ldc "WITH query AS ("
invokevirtual java.lang.StringBuilder.insert:(ILjava/lang/String;)Ljava/lang/StringBuilder;
ldc ") SELECT "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " FROM query "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
10: aload 1
ldc "WHERE __hibernate_row_nr__ >= ? AND __hibernate_row_nr__ < ?"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 3 end local 2 11: goto 14
12: StackMap locals:
StackMap stack:
aload 0
iconst_0
putfield org.hibernate.dialect.pagination.SQLServer2005LimitHandler.hasOffset:Z
13: aload 0
aload 1
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.addTopExpression:(Ljava/lang/StringBuilder;)V
14: StackMap locals:
StackMap stack:
aload 1
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
1 15 1 sb Ljava/lang/StringBuilder;
5 11 2 selectClause Ljava/lang/String;
6 11 3 orderByIndex I
public int bindLimitParametersAtStartOfQuery(java.sql.PreparedStatement, int);
descriptor: (Ljava/sql/PreparedStatement;I)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.hibernate.dialect.pagination.SQLServer2005LimitHandler.topAdded:Z
ifeq 3
1: aload 1
iload 2
aload 0
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.getMaxOrLimit:()I
iconst_1
isub
invokeinterface java.sql.PreparedStatement.setInt:(II)V
2: iconst_1
ireturn
3: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 4 1 statement Ljava/sql/PreparedStatement;
0 4 2 index I
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
statement
index
public int bindLimitParametersAtEndOfQuery(java.sql.PreparedStatement, int);
descriptor: (Ljava/sql/PreparedStatement;I)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.hibernate.dialect.pagination.SQLServer2005LimitHandler.hasOffset:Z
ifeq 1
aload 0
aload 1
iload 2
invokespecial org.hibernate.dialect.pagination.AbstractLimitHandler.bindLimitParametersAtEndOfQuery:(Ljava/sql/PreparedStatement;I)I
goto 2
StackMap locals:
StackMap stack:
1: iconst_0
StackMap locals:
StackMap stack: int
2: ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 3 1 statement Ljava/sql/PreparedStatement;
0 3 2 index I
Exceptions:
throws java.sql.SQLException
MethodParameters:
Name Flags
statement
index
protected java.lang.String fillAliasInSelectClause(java.lang.StringBuilder);
descriptor: (Ljava/lang/StringBuilder;)Ljava/lang/String;
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=12, args_size=2
start local 0 start local 1 0: new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
astore 2
start local 2 1: aload 1
ldc "select "
iconst_0
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOf:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 3
start local 3 2: aload 1
ldc "from"
iload 3
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOfWord:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 4
start local 4 3: iload 3
istore 5
start local 5 4: iload 3
istore 6
start local 6 5: iconst_0
istore 7
start local 7 6: iconst_0
istore 8
start local 8 7: goto 27
8: StackMap locals: org.hibernate.dialect.pagination.SQLServer2005LimitHandler java.lang.StringBuilder java.util.List int int int int int int
StackMap stack:
iload 5
istore 6
9: aload 1
ldc ","
iload 5
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOf:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 5
10: iload 5
iload 4
if_icmple 12
11: goto 28
12: StackMap locals:
StackMap stack:
iload 5
iconst_m1
if_icmpeq 27
13: aload 1
iload 6
iload 5
invokevirtual java.lang.StringBuilder.substring:(II)Ljava/lang/String;
astore 9
start local 9 14: aload 0
aload 9
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.selectsMultipleColumns:(Ljava/lang/String;)Z
ifeq 17
15: iconst_1
istore 8
16: goto 26
17: StackMap locals: java.lang.String
StackMap stack:
aload 0
aload 9
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.getAlias:(Ljava/lang/String;)Ljava/lang/String;
astore 10
start local 10 18: aload 10
ifnonnull 25
19: ldc "page"
iload 7
invokestatic org.hibernate.internal.util.StringHelper.generateAlias:(Ljava/lang/String;I)Ljava/lang/String;
astore 10
20: aload 1
iload 5
new java.lang.StringBuilder
dup
ldc " as "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 10
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.insert:(ILjava/lang/String;)Ljava/lang/StringBuilder;
pop
21: new java.lang.StringBuilder
dup
ldc " as "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 10
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.lang.String.length:()I
istore 11
start local 11 22: iinc 7 1
23: iload 5
iload 11
iadd
istore 5
24: iload 4
iload 11
iadd
istore 4
end local 11 25: StackMap locals: java.lang.String
StackMap stack:
aload 2
aload 10
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 10 26: StackMap locals:
StackMap stack:
iinc 5 1
end local 9 27: StackMap locals:
StackMap stack:
iload 5
iconst_m1
if_icmpne 8
28: StackMap locals:
StackMap stack:
aload 1
ldc "from"
iload 3
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOfWord:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 4
29: aload 1
iload 6
iload 4
invokevirtual java.lang.StringBuilder.substring:(II)Ljava/lang/String;
astore 9
start local 9 30: aload 0
aload 9
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.selectsMultipleColumns:(Ljava/lang/String;)Z
ifeq 33
31: iconst_1
istore 8
32: goto 38
33: StackMap locals: java.lang.String
StackMap stack:
aload 0
aload 9
invokevirtual org.hibernate.dialect.pagination.SQLServer2005LimitHandler.getAlias:(Ljava/lang/String;)Ljava/lang/String;
astore 10
start local 10 34: aload 10
ifnonnull 37
35: ldc "page"
iload 7
invokestatic org.hibernate.internal.util.StringHelper.generateAlias:(Ljava/lang/String;I)Ljava/lang/String;
astore 10
36: aload 1
iload 4
iconst_1
isub
new java.lang.StringBuilder
dup
ldc " as "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 10
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.insert:(ILjava/lang/String;)Ljava/lang/StringBuilder;
pop
37: StackMap locals: java.lang.String
StackMap stack:
aload 2
aload 10
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 10 38: StackMap locals:
StackMap stack:
iload 8
ifeq 39
ldc "*"
goto 40
StackMap locals:
StackMap stack:
39: ldc ", "
aload 2
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
invokestatic org.hibernate.internal.util.StringHelper.join:(Ljava/lang/String;Ljava/util/Iterator;)Ljava/lang/String;
StackMap locals:
StackMap stack: java.lang.String
40: 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 41 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 41 1 sb Ljava/lang/StringBuilder;
1 41 2 aliases Ljava/util/List<Ljava/lang/String;>;
2 41 3 startPos I
3 41 4 endPos I
4 41 5 nextComa I
5 41 6 prevComa I
6 41 7 unique I
7 41 8 selectsMultipleColumns Z
14 27 9 expression Ljava/lang/String;
18 26 10 alias Ljava/lang/String;
22 25 11 aliasExprLength I
30 41 9 expression Ljava/lang/String;
34 38 10 alias Ljava/lang/String;
MethodParameters:
Name Flags
sb
private boolean selectsMultipleColumns(java.lang.String);
descriptor: (Ljava/lang/String;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual java.lang.String.trim:()Ljava/lang/String;
ldc "(?i)(.)*\\s"
ldc ""
invokevirtual java.lang.String.replaceFirst:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
astore 2
start local 2 1: ldc "*"
aload 2
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifne 2
aload 2
ldc ".*"
invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
ifne 2
iconst_0
ireturn
StackMap locals: java.lang.String
StackMap stack:
2: iconst_1
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 3 1 expression Ljava/lang/String;
1 3 2 lastExpr Ljava/lang/String;
MethodParameters:
Name Flags
expression
private java.lang.String getAlias(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: getstatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.ALIAS_PATTERN:Ljava/util/regex/Pattern;
aload 1
invokevirtual java.util.regex.Pattern.matcher:(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
astore 2
start local 2 1: aload 2
invokevirtual java.util.regex.Matcher.find:()Z
ifeq 3
2: aload 2
iconst_0
invokevirtual java.util.regex.Matcher.group:(I)Ljava/lang/String;
ldc "(?i)(.)*\\sas\\s"
ldc ""
invokevirtual java.lang.String.replaceFirst:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
invokevirtual java.lang.String.trim:()Ljava/lang/String;
areturn
3: StackMap locals: java.util.regex.Matcher
StackMap stack:
aconst_null
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 4 1 expression Ljava/lang/String;
1 4 2 matcher Ljava/util/regex/Matcher;
MethodParameters:
Name Flags
expression
protected void encloseWithOuterQuery(java.lang.StringBuilder);
descriptor: (Ljava/lang/StringBuilder;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 1
iconst_0
ldc "SELECT inner_query.*, ROW_NUMBER() OVER (ORDER BY CURRENT_TIMESTAMP) as __hibernate_row_nr__ FROM ( "
invokevirtual java.lang.StringBuilder.insert:(ILjava/lang/String;)Ljava/lang/StringBuilder;
pop
1: aload 1
ldc " ) inner_query "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 3 1 sql Ljava/lang/StringBuilder;
MethodParameters:
Name Flags
sql
protected void addTopExpression(java.lang.StringBuilder);
descriptor: (Ljava/lang/StringBuilder;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: aload 1
ldc "distinct"
iconst_0
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOfWord:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 2
start local 2 1: iload 2
ifle 4
2: aload 1
iload 2
ldc "distinct"
invokevirtual java.lang.String.length:()I
iadd
ldc " TOP(?)"
invokevirtual java.lang.StringBuilder.insert:(ILjava/lang/String;)Ljava/lang/StringBuilder;
pop
3: goto 6
4: StackMap locals: int
StackMap stack:
aload 1
ldc "select "
iconst_0
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOf:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 3
start local 3 5: aload 1
iload 3
ldc "select"
invokevirtual java.lang.String.length:()I
iadd
ldc " TOP(?)"
invokevirtual java.lang.StringBuilder.insert:(ILjava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 3 6: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield org.hibernate.dialect.pagination.SQLServer2005LimitHandler.topAdded:Z
7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/hibernate/dialect/pagination/SQLServer2005LimitHandler;
0 8 1 sql Ljava/lang/StringBuilder;
1 8 2 distinctStartPos I
5 6 3 selectStartPos I
MethodParameters:
Name Flags
sql
private static int shallowIndexOfWord(java.lang.StringBuilder, java.lang.String, int);
descriptor: (Ljava/lang/StringBuilder;Ljava/lang/String;I)I
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
new java.lang.StringBuilder
dup
bipush 32
invokestatic java.lang.String.valueOf:(C)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
bipush 32
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iload 2
invokestatic org.hibernate.dialect.pagination.SQLServer2005LimitHandler.shallowIndexOf:(Ljava/lang/StringBuilder;Ljava/lang/String;I)I
istore 3
start local 3 1: iload 3
iconst_m1
if_icmpeq 2
iload 3
iconst_1
iadd
goto 3
StackMap locals: int
StackMap stack:
2: iconst_m1
StackMap locals:
StackMap stack: int
3: ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 sb Ljava/lang/StringBuilder;
0 4 1 search Ljava/lang/String;
0 4 2 fromIndex I
1 4 3 index I
MethodParameters:
Name Flags
sb final
search final
fromIndex
private static int shallowIndexOf(java.lang.StringBuilder, java.lang.String, int);
descriptor: (Ljava/lang/StringBuilder;Ljava/lang/String;I)I
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=11, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
getstatic java.util.Locale.ROOT:Ljava/util/Locale;
invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
astore 3
start local 3 1: aload 3
invokevirtual java.lang.String.length:()I
istore 4
start local 4 2: aload 1
invokevirtual java.lang.String.length:()I
istore 5
start local 5 3: iconst_m1
istore 6
start local 6 4: iconst_0
istore 7
start local 7 5: iload 2
istore 8
start local 8 6: StackMap locals: java.lang.StringBuilder java.lang.String int java.lang.String int int int int int
StackMap stack:
aload 3
aload 1
iload 8
invokevirtual java.lang.String.indexOf:(Ljava/lang/String;I)I
istore 6
7: iload 6
iconst_m1
if_icmpeq 19
8: iload 8
istore 9
start local 9 9: goto 17
10: StackMap locals: int
StackMap stack:
aload 0
iload 9
invokevirtual java.lang.StringBuilder.charAt:(I)C
istore 10
start local 10 11: iload 10
bipush 40
if_icmpne 14
12: iinc 7 1
13: goto 16
14: StackMap locals: int
StackMap stack:
iload 10
bipush 41
if_icmpne 16
15: iinc 7 -1
end local 10 16: StackMap locals:
StackMap stack:
iinc 9 1
StackMap locals:
StackMap stack:
17: iload 9
iload 6
if_icmplt 10
end local 9 18: iload 6
iload 5
iadd
istore 8
19: StackMap locals:
StackMap stack:
iload 8
iload 4
if_icmpge 20
iload 7
ifeq 20
iload 6
iconst_m1
if_icmpne 6
20: StackMap locals:
StackMap stack:
iload 7
ifne 21
iload 6
goto 22
StackMap locals:
StackMap stack:
21: iconst_m1
StackMap locals:
StackMap stack: int
22: ireturn
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 23 0 sb Ljava/lang/StringBuilder;
0 23 1 search Ljava/lang/String;
0 23 2 fromIndex I
1 23 3 lowercase Ljava/lang/String;
2 23 4 len I
3 23 5 searchlen I
4 23 6 pos I
5 23 7 depth I
6 23 8 cur I
9 18 9 iter I
11 16 10 c C
MethodParameters:
Name Flags
sb
search
fromIndex
}
SourceFile: "SQLServer2005LimitHandler.java"