Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Quincy379
jadx
提交
009749cf
J
jadx
项目概览
Quincy379
/
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,发现更多精彩内容 >>
提交
009749cf
编写于
5月 28, 2017
作者:
S
Skylot
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
core: ignore errors in debug info parser (fix #176)
上级
da94e7b1
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
56 addition
and
29 deletion
+56
-29
jadx-core/src/main/java/jadx/core/dex/visitors/DebugInfoVisitor.java
...rc/main/java/jadx/core/dex/visitors/DebugInfoVisitor.java
+56
-29
未找到文件。
jadx-core/src/main/java/jadx/core/dex/visitors/DebugInfoVisitor.java
浏览文件 @
009749cf
package
jadx.core.dex.visitors
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
jadx.core.dex.instructions.args.ArgType
;
import
jadx.core.dex.instructions.args.RegisterArg
;
import
jadx.core.dex.nodes.BlockNode
;
...
...
@@ -7,40 +10,50 @@ import jadx.core.dex.nodes.InsnNode;
import
jadx.core.dex.nodes.MethodNode
;
import
jadx.core.dex.nodes.parser.DebugInfoParser
;
import
jadx.core.utils.BlockUtils
;
import
jadx.core.utils.ErrorsCounter
;
import
jadx.core.utils.exceptions.DecodeException
;
import
jadx.core.utils.exceptions.JadxException
;
public
class
DebugInfoVisitor
extends
AbstractVisitor
{
private
static
final
Logger
LOG
=
LoggerFactory
.
getLogger
(
DebugInfoVisitor
.
class
);
@Override
public
void
visit
(
MethodNode
mth
)
throws
JadxException
{
int
debugOffset
=
mth
.
getDebugInfoOffset
();
if
(
debugOffset
>
0
)
{
InsnNode
[]
insnArr
=
mth
.
getInstructions
();
DebugInfoParser
debugInfoParser
=
new
DebugInfoParser
(
mth
,
debugOffset
,
insnArr
);
debugInfoParser
.
process
();
// set method source line from first instruction
if
(
insnArr
.
length
!=
0
)
{
for
(
InsnNode
insn
:
insnArr
)
{
if
(
insn
!=
null
)
{
int
line
=
insn
.
getSourceLine
();
if
(
line
!=
0
)
{
mth
.
setSourceLine
(
line
-
1
);
}
break
;
}
}
try
{
int
debugOffset
=
mth
.
getDebugInfoOffset
();
if
(
debugOffset
>
0
)
{
processDebugInfo
(
mth
,
debugOffset
);
}
if
(!
mth
.
getReturnType
().
equals
(
ArgType
.
VOID
))
{
// fix debug info for splitter 'return' instructions
for
(
BlockNode
exit
:
mth
.
getExitBlocks
())
{
InsnNode
ret
=
BlockUtils
.
getLastInsn
(
exit
);
if
(
ret
==
null
)
{
continue
;
}
InsnNode
oldRet
=
insnArr
[
ret
.
getOffset
()];
if
(
oldRet
==
ret
)
{
continue
;
}
}
catch
(
Exception
e
)
{
LOG
.
error
(
"Error in debug info parser: "
+
ErrorsCounter
.
formatErrorMsg
(
mth
,
e
.
getMessage
()),
e
);
}
finally
{
mth
.
unloadInsnArr
();
}
}
private
void
processDebugInfo
(
MethodNode
mth
,
int
debugOffset
)
throws
DecodeException
{
InsnNode
[]
insnArr
=
mth
.
getInstructions
();
DebugInfoParser
debugInfoParser
=
new
DebugInfoParser
(
mth
,
debugOffset
,
insnArr
);
debugInfoParser
.
process
();
if
(
insnArr
.
length
!=
0
)
{
setMethodSourceLine
(
mth
,
insnArr
);
}
if
(!
mth
.
getReturnType
().
equals
(
ArgType
.
VOID
))
{
setLineForReturn
(
mth
,
insnArr
);
}
}
/**
* Fix debug info for splitter 'return' instructions
*/
private
void
setLineForReturn
(
MethodNode
mth
,
InsnNode
[]
insnArr
)
{
for
(
BlockNode
exit
:
mth
.
getExitBlocks
())
{
InsnNode
ret
=
BlockUtils
.
getLastInsn
(
exit
);
if
(
ret
!=
null
)
{
InsnNode
oldRet
=
insnArr
[
ret
.
getOffset
()];
if
(
oldRet
!=
ret
)
{
RegisterArg
oldArg
=
(
RegisterArg
)
oldRet
.
getArg
(
0
);
RegisterArg
newArg
=
(
RegisterArg
)
ret
.
getArg
(
0
);
newArg
.
mergeDebugInfo
(
oldArg
.
getType
(),
oldArg
.
getName
());
...
...
@@ -48,6 +61,20 @@ public class DebugInfoVisitor extends AbstractVisitor {
}
}
}
mth
.
unloadInsnArr
();
}
/**
* Set method source line from first instruction
*/
private
void
setMethodSourceLine
(
MethodNode
mth
,
InsnNode
[]
insnArr
)
{
for
(
InsnNode
insn
:
insnArr
)
{
if
(
insn
!=
null
)
{
int
line
=
insn
.
getSourceLine
();
if
(
line
!=
0
)
{
mth
.
setSourceLine
(
line
-
1
);
}
return
;
}
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录