本文整理汇总了Java中org.jf.util.LinearSearch类的典型用法代码示例。如果您正苦于以下问题:Java LinearSearch类的具体用法?Java LinearSearch怎么用?Java LinearSearch使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
LinearSearch类属于org.jf.util包,在下文中一共展示了LinearSearch类的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。
示例1: parameter
import org.jf.util.LinearSearch; //导入依赖的package包/类
public final void parameter(List<SmaliMethodParameter> parameters) throws RecognitionException {
CommonTree REGISTER86=null;
CommonTree I_PARAMETER87=null;
String string_literal88 =null;
Set<Annotation> annotations89 =null;
try {
// D:\\decomplier_tools\\smali\\smali\\smali\\src\\main\\antlr3\\smaliTreeWalker.g:553:3: ( ^( I_PARAMETER REGISTER ( string_literal )? annotations ) )
// D:\\decomplier_tools\\smali\\smali\\smali\\src\\main\\antlr3\\smaliTreeWalker.g:553:5: ^( I_PARAMETER REGISTER ( string_literal )? annotations )
{
I_PARAMETER87=(CommonTree)match(input,I_PARAMETER,FOLLOW_I_PARAMETER_in_parameter1410);
match(input, Token.DOWN, null);
REGISTER86=(CommonTree)match(input,REGISTER,FOLLOW_REGISTER_in_parameter1412);
// D:\\decomplier_tools\\smali\\smali\\smali\\src\\main\\antlr3\\smaliTreeWalker.g:553:28: ( string_literal )?
int alt22=2;
int LA22_0 = input.LA(1);
if ( (LA22_0==STRING_LITERAL) ) {
alt22=1;
}
switch (alt22) {
case 1 :
// D:\\decomplier_tools\\smali\\smali\\smali\\src\\main\\antlr3\\smaliTreeWalker.g:553:28: string_literal
{
pushFollow(FOLLOW_string_literal_in_parameter1414);
string_literal88=string_literal();
state._fsp--;
}
break;
}
pushFollow(FOLLOW_annotations_in_parameter1417);
annotations89=annotations();
state._fsp--;
match(input, Token.UP, null);
final int registerNumber = parseRegister_short((REGISTER86!=null?REGISTER86.getText():null));
int totalMethodRegisters = method_stack.peek().totalMethodRegisters;
int methodParameterRegisters = method_stack.peek().methodParameterRegisters;
if (registerNumber >= totalMethodRegisters) {
throw new SemanticException(input, I_PARAMETER87, "Register %s is larger than the maximum register v%d " +
"for this method", (REGISTER86!=null?REGISTER86.getText():null), totalMethodRegisters-1);
}
final int indexGuess = registerNumber - (totalMethodRegisters - methodParameterRegisters) - (method_stack.peek().isStatic?0:1);
if (indexGuess < 0) {
throw new SemanticException(input, I_PARAMETER87, "Register %s is not a parameter register.",
(REGISTER86!=null?REGISTER86.getText():null));
}
int parameterIndex = LinearSearch.linearSearch(parameters, SmaliMethodParameter.COMPARATOR,
new WithRegister() { public int getRegister() { return indexGuess; } },
indexGuess);
if (parameterIndex < 0) {
throw new SemanticException(input, I_PARAMETER87, "Register %s is the second half of a wide parameter.",
(REGISTER86!=null?REGISTER86.getText():null));
}
SmaliMethodParameter methodParameter = parameters.get(parameterIndex);
methodParameter.name = string_literal88;
if (annotations89 != null && annotations89.size() > 0) {
methodParameter.annotations = annotations89;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
开发者ID:Miracle963,项目名称:zjdroid,代码行数:81,代码来源:smaliTreeWalker.java
示例2: parameter
import org.jf.util.LinearSearch; //导入依赖的package包/类
public final void parameter(List<SmaliMethodParameter> parameters) throws RecognitionException {
CommonTree REGISTER86=null;
CommonTree I_PARAMETER87=null;
String string_literal88 =null;
Set<Annotation> annotations89 =null;
try {
// /usr/local/google/home/bgruv/android/aosp-master/external/smali/smali/src/main/antlr3/smaliTreeWalker.g:553:3: ( ^( I_PARAMETER REGISTER ( string_literal )? annotations ) )
// /usr/local/google/home/bgruv/android/aosp-master/external/smali/smali/src/main/antlr3/smaliTreeWalker.g:553:5: ^( I_PARAMETER REGISTER ( string_literal )? annotations )
{
I_PARAMETER87=(CommonTree)match(input,I_PARAMETER,FOLLOW_I_PARAMETER_in_parameter1410);
match(input, Token.DOWN, null);
REGISTER86=(CommonTree)match(input,REGISTER,FOLLOW_REGISTER_in_parameter1412);
// /usr/local/google/home/bgruv/android/aosp-master/external/smali/smali/src/main/antlr3/smaliTreeWalker.g:553:28: ( string_literal )?
int alt22=2;
int LA22_0 = input.LA(1);
if ( (LA22_0==STRING_LITERAL) ) {
alt22=1;
}
switch (alt22) {
case 1 :
// /usr/local/google/home/bgruv/android/aosp-master/external/smali/smali/src/main/antlr3/smaliTreeWalker.g:553:28: string_literal
{
pushFollow(FOLLOW_string_literal_in_parameter1414);
string_literal88=string_literal();
state._fsp--;
}
break;
}
pushFollow(FOLLOW_annotations_in_parameter1417);
annotations89=annotations();
state._fsp--;
match(input, Token.UP, null);
final int registerNumber = parseRegister_short((REGISTER86!=null?REGISTER86.getText():null));
int totalMethodRegisters = method_stack.peek().totalMethodRegisters;
int methodParameterRegisters = method_stack.peek().methodParameterRegisters;
if (registerNumber >= totalMethodRegisters) {
throw new SemanticException(input, I_PARAMETER87, "Register %s is larger than the maximum register v%d " +
"for this method", (REGISTER86!=null?REGISTER86.getText():null), totalMethodRegisters-1);
}
final int indexGuess = registerNumber - (totalMethodRegisters - methodParameterRegisters) - (method_stack.peek().isStatic?0:1);
if (indexGuess < 0) {
throw new SemanticException(input, I_PARAMETER87, "Register %s is not a parameter register.",
(REGISTER86!=null?REGISTER86.getText():null));
}
int parameterIndex = LinearSearch.linearSearch(parameters, SmaliMethodParameter.COMPARATOR,
new WithRegister() { public int getRegister() { return indexGuess; } },
indexGuess);
if (parameterIndex < 0) {
throw new SemanticException(input, I_PARAMETER87, "Register %s is the second half of a wide parameter.",
(REGISTER86!=null?REGISTER86.getText():null));
}
SmaliMethodParameter methodParameter = parameters.get(parameterIndex);
methodParameter.name = string_literal88;
if (annotations89 != null && annotations89.size() > 0) {
methodParameter.annotations = annotations89;
}
}
}
catch (RecognitionException re) {
reportError(re);
recover(input,re);
}
finally {
// do for sure before leaving
}
}
开发者ID:Sukelluskello,项目名称:VectorAttackScanner,代码行数:81,代码来源:smaliTreeWalker.java
注:本文中的org.jf.util.LinearSearch类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论