Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Quincy379
jadx
提交
6428f293
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,体验更适合开发者的 AI 搜索 >>
提交
6428f293
编写于
9月 17, 2020
作者:
S
Skylot
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: don't add @Override for static methods (#976)
上级
cfaa6ab6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
41 addition
and
2 deletion
+41
-2
jadx-core/src/main/java/jadx/core/dex/visitors/OverrideMethodVisitor.java
...in/java/jadx/core/dex/visitors/OverrideMethodVisitor.java
+5
-2
jadx-core/src/test/java/jadx/tests/integration/others/TestOverrideStaticMethod.java
...dx/tests/integration/others/TestOverrideStaticMethod.java
+36
-0
未找到文件。
jadx-core/src/main/java/jadx/core/dex/visitors/OverrideMethodVisitor.java
浏览文件 @
6428f293
...
...
@@ -9,6 +9,7 @@ import java.util.Objects;
import
jadx.core.clsp.ClspClass
;
import
jadx.core.clsp.ClspMethod
;
import
jadx.core.dex.attributes.nodes.MethodOverrideAttr
;
import
jadx.core.dex.info.AccessInfo
;
import
jadx.core.dex.instructions.args.ArgType
;
import
jadx.core.dex.nodes.ClassNode
;
import
jadx.core.dex.nodes.IMethodDetails
;
...
...
@@ -33,7 +34,7 @@ public class OverrideMethodVisitor extends AbstractVisitor {
RootNode
root
=
cls
.
root
();
List
<
ArgType
>
superTypes
=
collectSuperTypes
(
cls
);
for
(
MethodNode
mth
:
cls
.
getMethods
())
{
if
(
mth
.
isConstructor
())
{
if
(
mth
.
isConstructor
()
||
mth
.
getAccessFlags
().
isStatic
()
)
{
continue
;
}
String
signature
=
mth
.
getMethodInfo
().
makeSignature
(
false
);
...
...
@@ -53,7 +54,9 @@ public class OverrideMethodVisitor extends AbstractVisitor {
ClassNode
classNode
=
root
.
resolveClass
(
superType
);
if
(
classNode
!=
null
)
{
for
(
MethodNode
mth
:
classNode
.
getMethods
())
{
if
(!
mth
.
getAccessFlags
().
isPrivate
())
{
AccessInfo
accessFlags
=
mth
.
getAccessFlags
();
if
(!
accessFlags
.
isPrivate
()
&&
!
accessFlags
.
isStatic
())
{
String
mthShortId
=
mth
.
getMethodInfo
().
getShortId
();
if
(
mthShortId
.
startsWith
(
signature
))
{
overrideList
.
add
(
mth
);
...
...
jadx-core/src/test/java/jadx/tests/integration/others/TestOverrideStaticMethod.java
0 → 100644
浏览文件 @
6428f293
package
jadx.tests.integration.others
;
import
org.junit.jupiter.api.Test
;
import
jadx.tests.api.IntegrationTest
;
import
static
jadx
.
tests
.
api
.
utils
.
assertj
.
JadxAssertions
.
assertThat
;
public
class
TestOverrideStaticMethod
extends
IntegrationTest
{
public
static
class
TestCls
{
public
static
class
BaseClass
{
public
static
int
a
()
{
return
1
;
}
}
public
static
class
MyClass
extends
BaseClass
{
public
static
int
a
()
{
return
2
;
}
}
public
void
check
()
{
assertThat
(
BaseClass
.
a
()).
isEqualTo
(
1
);
assertThat
(
MyClass
.
a
()).
isEqualTo
(
2
);
}
}
@Test
public
void
test
()
{
assertThat
(
getClassNode
(
TestCls
.
class
))
.
code
()
.
doesNotContain
(
"@Override"
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录