Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
qq_39073359
jadx
提交
33c5e082
J
jadx
项目概览
qq_39073359
/
jadx
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jadx
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
33c5e082
编写于
7月 29, 2014
作者:
S
Skylot
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
core: always check arguments before inline
上级
cbd36aeb
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
53 addition
and
8 deletion
+53
-8
jadx-core/src/main/java/jadx/core/dex/visitors/CodeShrinker.java
...re/src/main/java/jadx/core/dex/visitors/CodeShrinker.java
+5
-8
jadx-core/src/test/java/jadx/tests/internal/inline/TestInlineInLoop.java
...est/java/jadx/tests/internal/inline/TestInlineInLoop.java
+48
-0
未找到文件。
jadx-core/src/main/java/jadx/core/dex/visitors/CodeShrinker.java
浏览文件 @
33c5e082
...
...
@@ -87,7 +87,8 @@ public class CodeShrinker extends AbstractVisitor {
}
public
WrapInfo
checkInline
(
int
assignPos
,
RegisterArg
arg
)
{
if
(
assignPos
>=
inlineBorder
||
!
canMove
(
assignPos
,
inlineBorder
))
{
if
(!
arg
.
isThis
()
&&
(
assignPos
>=
inlineBorder
||
!
canMove
(
assignPos
,
inlineBorder
)))
{
return
null
;
}
inlineBorder
=
assignPos
;
...
...
@@ -205,13 +206,9 @@ public class CodeShrinker extends AbstractVisitor {
}
int
assignPos
=
insnList
.
getIndex
(
assignInsn
);
if
(
assignPos
!=
-
1
)
{
if
(
assignInsn
.
canReorder
())
{
wrapList
.
add
(
argsInfo
.
inline
(
assignPos
,
arg
));
}
else
{
WrapInfo
wrapInfo
=
argsInfo
.
checkInline
(
assignPos
,
arg
);
if
(
wrapInfo
!=
null
)
{
wrapList
.
add
(
wrapInfo
);
}
WrapInfo
wrapInfo
=
argsInfo
.
checkInline
(
assignPos
,
arg
);
if
(
wrapInfo
!=
null
)
{
wrapList
.
add
(
wrapInfo
);
}
}
else
{
// another block
...
...
jadx-core/src/test/java/jadx/tests/internal/inline/TestInlineInLoop.java
0 → 100644
浏览文件 @
33c5e082
package
jadx.tests.internal.inline
;
import
jadx.api.InternalJadxTest
;
import
jadx.core.dex.nodes.ClassNode
;
import
org.junit.Test
;
import
static
jadx
.
tests
.
utils
.
JadxMatchers
.
containsOne
;
import
static
jadx
.
tests
.
utils
.
JadxMatchers
.
countString
;
import
static
org
.
junit
.
Assert
.
assertThat
;
public
class
TestInlineInLoop
extends
InternalJadxTest
{
public
static
class
TestCls
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
int
a
=
0
;
int
b
=
4
;
int
c
=
0
;
while
(
a
<
12
)
{
if
(
b
+
a
<
9
&&
b
<
8
)
{
if
(
b
>=
2
&&
a
>
-
1
&&
b
<
6
)
{
System
.
out
.
println
(
"OK"
);
c
=
b
+
1
;
}
c
=
b
;
}
c
=
b
;
b
++;
b
=
c
;
a
++;
}
}
}
@Test
public
void
test
()
{
ClassNode
cls
=
getClassNode
(
TestCls
.
class
);
String
code
=
cls
.
getCode
().
toString
();
System
.
out
.
println
(
code
);
assertThat
(
code
,
containsOne
(
"int c"
));
assertThat
(
code
,
containsOne
(
"c = b + 1"
));
assertThat
(
code
,
countString
(
2
,
"c = b;"
));
assertThat
(
code
,
containsOne
(
"b++;"
));
assertThat
(
code
,
containsOne
(
"b = c"
));
assertThat
(
code
,
containsOne
(
"a++;"
));
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录