Skip to content

Commit

Permalink
8280132: Incorrect comparator com.sun.beans.introspect.MethodInfo.Met…
Browse files Browse the repository at this point in the history
…hodOrder

Backport-of: 2f46af05ce2d43e19e0095680eb3a52fd904c774
  • Loading branch information
mrserb committed Jan 3, 2023
1 parent 0ac93eb commit ef94eb7
Show file tree
Hide file tree
Showing 2 changed files with 1,528 additions and 29 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2014, 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
Expand Down Expand Up @@ -98,10 +98,7 @@ static List<Method> get(Class<?> type) {

/**
* A comparator that defines a total order so that methods have the same
* name and identical signatures appear next to each others. The methods are
* sorted in such a way that methods which override each other will sit next
* to each other, with the overridden method last - e.g. is Integer getFoo()
* placed before Object getFoo().
* name and identical signatures appear next to each others.
**/
private static final class MethodOrder implements Comparator<Method> {

Expand Down Expand Up @@ -132,18 +129,7 @@ public int compare(final Method a, final Method b) {
}
final Class<?> aret = a.getReturnType();
final Class<?> bret = b.getReturnType();
if (aret == bret) {
return 0;
}

// Super type comes last: Integer, Number, Object
if (aret.isAssignableFrom(bret)) {
return 1;
}
if (bret.isAssignableFrom(aret)) {
return -1;
}
return aret.getName().compareTo(bret.getName());
return aret == bret ? 0 : aret.getName().compareTo(bret.getName());
}

static final MethodOrder instance = new MethodOrder();
Expand Down
Loading

1 comment on commit ef94eb7

@openjdk-notifier
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.