Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
keyescgm
jadx
提交
7a14aaa1
J
jadx
项目概览
keyescgm
/
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,发现更多精彩内容 >>
提交
7a14aaa1
编写于
3月 02, 2021
作者:
S
Skylot
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: resolve variable name shadowing in anonymous classes (#1124)
上级
65086383
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
81 addition
and
8 deletion
+81
-8
jadx-core/src/main/java/jadx/core/codegen/ClassGen.java
jadx-core/src/main/java/jadx/core/codegen/ClassGen.java
+16
-4
jadx-core/src/main/java/jadx/core/codegen/InsnGen.java
jadx-core/src/main/java/jadx/core/codegen/InsnGen.java
+4
-1
jadx-core/src/main/java/jadx/core/codegen/MethodGen.java
jadx-core/src/main/java/jadx/core/codegen/MethodGen.java
+1
-1
jadx-core/src/main/java/jadx/core/codegen/NameGen.java
jadx-core/src/main/java/jadx/core/codegen/NameGen.java
+6
-2
jadx-core/src/test/java/jadx/tests/integration/names/TestDuplicateVarNames.java
...a/jadx/tests/integration/names/TestDuplicateVarNames.java
+54
-0
未找到文件。
jadx-core/src/main/java/jadx/core/codegen/ClassGen.java
浏览文件 @
7a14aaa1
...
@@ -11,6 +11,7 @@ import java.util.Objects;
...
@@ -11,6 +11,7 @@ import java.util.Objects;
import
java.util.Set
;
import
java.util.Set
;
import
java.util.stream.Stream
;
import
java.util.stream.Stream
;
import
org.jetbrains.annotations.NotNull
;
import
org.jetbrains.annotations.Nullable
;
import
org.jetbrains.annotations.Nullable
;
import
jadx.api.ICodeInfo
;
import
jadx.api.ICodeInfo
;
...
@@ -59,6 +60,9 @@ public class ClassGen {
...
@@ -59,6 +60,9 @@ public class ClassGen {
private
boolean
bodyGenStarted
;
private
boolean
bodyGenStarted
;
@Nullable
private
NameGen
outerNameGen
;
public
ClassGen
(
ClassNode
cls
,
JadxArgs
jadxArgs
)
{
public
ClassGen
(
ClassNode
cls
,
JadxArgs
jadxArgs
)
{
this
(
cls
,
null
,
jadxArgs
.
isUseImports
(),
jadxArgs
.
isFallbackMode
(),
jadxArgs
.
isShowInconsistentCode
());
this
(
cls
,
null
,
jadxArgs
.
isUseImports
(),
jadxArgs
.
isFallbackMode
(),
jadxArgs
.
isShowInconsistentCode
());
}
}
...
@@ -238,13 +242,12 @@ public class ClassGen {
...
@@ -238,13 +242,12 @@ public class ClassGen {
*/
*/
public
void
addClassBody
(
ICodeWriter
clsCode
,
boolean
printClassName
)
throws
CodegenException
{
public
void
addClassBody
(
ICodeWriter
clsCode
,
boolean
printClassName
)
throws
CodegenException
{
clsCode
.
add
(
'{'
);
clsCode
.
add
(
'{'
);
if
(
printClassName
)
{
clsCode
.
add
(
" // from class: "
+
cls
.
getClassInfo
().
getFullName
());
}
setBodyGenStarted
(
true
);
setBodyGenStarted
(
true
);
clsDeclOffset
=
clsCode
.
getLength
();
clsDeclOffset
=
clsCode
.
getLength
();
clsCode
.
incIndent
();
clsCode
.
incIndent
();
if
(
printClassName
)
{
clsCode
.
startLine
();
clsCode
.
add
(
"/* class "
+
cls
.
getFullName
()
+
" */"
);
}
addFields
(
clsCode
);
addFields
(
clsCode
);
addInnerClsAndMethods
(
clsCode
);
addInnerClsAndMethods
(
clsCode
);
clsCode
.
decIndent
();
clsCode
.
decIndent
();
...
@@ -746,4 +749,13 @@ public class ClassGen {
...
@@ -746,4 +749,13 @@ public class ClassGen {
public
void
setBodyGenStarted
(
boolean
bodyGenStarted
)
{
public
void
setBodyGenStarted
(
boolean
bodyGenStarted
)
{
this
.
bodyGenStarted
=
bodyGenStarted
;
this
.
bodyGenStarted
=
bodyGenStarted
;
}
}
@Nullable
public
NameGen
getOuterNameGen
()
{
return
outerNameGen
;
}
public
void
setOuterNameGen
(
@NotNull
NameGen
outerNameGen
)
{
this
.
outerNameGen
=
outerNameGen
;
}
}
}
jadx-core/src/main/java/jadx/core/codegen/InsnGen.java
浏览文件 @
7a14aaa1
...
@@ -725,7 +725,10 @@ public class InsnGen {
...
@@ -725,7 +725,10 @@ public class InsnGen {
MethodNode
callMth
=
mth
.
root
().
resolveMethod
(
insn
.
getCallMth
());
MethodNode
callMth
=
mth
.
root
().
resolveMethod
(
insn
.
getCallMth
());
generateMethodArguments
(
code
,
insn
,
0
,
callMth
);
generateMethodArguments
(
code
,
insn
,
0
,
callMth
);
code
.
add
(
' '
);
code
.
add
(
' '
);
new
ClassGen
(
cls
,
mgen
.
getClassGen
().
getParentGen
()).
addClassBody
(
code
,
true
);
ClassGen
classGen
=
new
ClassGen
(
cls
,
mgen
.
getClassGen
().
getParentGen
());
classGen
.
setOuterNameGen
(
mgen
.
getNameGen
());
classGen
.
addClassBody
(
code
,
true
);
}
}
private
void
makeInvoke
(
InvokeNode
insn
,
ICodeWriter
code
)
throws
CodegenException
{
private
void
makeInvoke
(
InvokeNode
insn
,
ICodeWriter
code
)
throws
CodegenException
{
...
...
jadx-core/src/main/java/jadx/core/codegen/MethodGen.java
浏览文件 @
7a14aaa1
...
@@ -58,7 +58,7 @@ public class MethodGen {
...
@@ -58,7 +58,7 @@ public class MethodGen {
this
.
mth
=
mth
;
this
.
mth
=
mth
;
this
.
classGen
=
classGen
;
this
.
classGen
=
classGen
;
this
.
annotationGen
=
classGen
.
getAnnotationGen
();
this
.
annotationGen
=
classGen
.
getAnnotationGen
();
this
.
nameGen
=
new
NameGen
(
mth
,
classGen
.
isFallbackMode
()
);
this
.
nameGen
=
new
NameGen
(
mth
,
classGen
);
}
}
public
ClassGen
getClassGen
()
{
public
ClassGen
getClassGen
()
{
...
...
jadx-core/src/main/java/jadx/core/codegen/NameGen.java
浏览文件 @
7a14aaa1
...
@@ -53,9 +53,13 @@ public class NameGen {
...
@@ -53,9 +53,13 @@ public class NameGen {
"java.lang.Exception"
,
"exc"
);
"java.lang.Exception"
,
"exc"
);
}
}
public
NameGen
(
MethodNode
mth
,
boolean
fallback
)
{
public
NameGen
(
MethodNode
mth
,
ClassGen
classGen
)
{
this
.
mth
=
mth
;
this
.
mth
=
mth
;
this
.
fallback
=
fallback
;
this
.
fallback
=
classGen
.
isFallbackMode
();
NameGen
outerNameGen
=
classGen
.
getOuterNameGen
();
if
(
outerNameGen
!=
null
)
{
inheritUsedNames
(
outerNameGen
);
}
addNamesUsedInClass
();
addNamesUsedInClass
();
}
}
...
...
jadx-core/src/test/java/jadx/tests/integration/names/TestDuplicateVarNames.java
0 → 100644
浏览文件 @
7a14aaa1
package
jadx.tests.integration.names
;
import
org.junit.jupiter.api.Test
;
import
jadx.core.dex.nodes.ClassNode
;
import
jadx.tests.api.IntegrationTest
;
import
static
jadx
.
tests
.
api
.
utils
.
assertj
.
JadxAssertions
.
assertThat
;
public
class
TestDuplicateVarNames
extends
IntegrationTest
{
public
static
class
TestCls
{
public
static
class
A
{
public
String
mth
(
A
a
)
{
return
null
;
}
@Override
public
String
toString
()
{
return
"1"
;
}
}
public
A
test
(
A
a
)
{
return
new
A
()
{
@Override
public
String
mth
(
A
innerA
)
{
return
a
+
"."
+
innerA
;
}
};
}
public
void
check
()
{
String
str
=
test
(
new
A
()).
mth
(
new
A
()
{
@Override
public
String
toString
()
{
return
"2"
;
}
});
assertThat
(
str
).
isEqualTo
(
"1.2"
);
}
}
@Test
public
void
test
()
{
noDebugInfo
();
ClassNode
cls
=
getClassNode
(
TestCls
.
class
);
assertThat
(
cls
)
.
code
()
.
doesNotContain
(
"return a + \".\" + a;"
)
.
doesNotContain
(
"AnonymousClass1"
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录