On Fri, 10 Jan 2025 21:53:20 GMT, Chen Liang <li...@openjdk.org> wrote:

>> The Type and AnnotatedType hierarchies have been enigmatic to new users: 
>> users have no clue how to categorize arbitrary type objects, when it is safe 
>> to cast to more specific types, and the exact conditions for method 
>> contracts.
>> 
>> A manifest is [JDK-8306039](https://bugs.openjdk.org/browse/JDK-8306039), 
>> where people are massively confused by the conditions for 
>> `ParameterizedType::getOwnerType` to return `null`.
>> 
>> To fix these problems, I consulted the JLS, used some terms from there and 
>> added JLS links to make the definitions concise and accurate.
>> 
>> Here are some actions:
>> 1. Add section for hierarchy overview for both Type and AnnotatedType
>> 2. Specify the underlying type for different AnnotatedType subinterfaces
>> 3. Define "inner member class" for `getOwnerType`, and refer to it in 
>> `AnnotatedType::getAnnotatedOwnerType`.
>> 4. Improve the specification for `ParameterizedType::getActualTypeArguments` 
>> to note the existence of owner types; also for annotated version
>> 5. Minor improvements to `ParameterizedType::getRawType`
>> 6. Move the equals specification for `ParameterizedType` to the actual 
>> `equals` method.
>> 
>> ApiDiff: 
>> https://cr.openjdk.org/~liach/apidiff/types-facelift/java.base/java/lang/reflect/package-summary.html
>> Javadoc: 
>> https://cr.openjdk.org/~liach/javadoc/types-facelift/java.base/java/lang/reflect/package-summary.html
>> 
>> Please review the associated CSR as well.
>
> Chen Liang has updated the pull request with a new target base due to a merge 
> or a rebase. The incremental webrev excludes the unrelated changes brought in 
> by the merge/rebase. The pull request contains 17 additional commits since 
> the last revision:
> 
>  - Year and typos
>  - Merge branch 'm5' into doc/owner-type
>  - Problems with owner type, kevin suggestions
>  - Slightly improve snippet
>  - Merge branch 'master' of https://github.com/openjdk/jdk into doc/owner-type
>  - Merge branch 'master' of https://github.com/openjdk/jdk into doc/owner-type
>  - Improve getRawType
>  - Intro and other various improvements
>  - Merge branch 'master' of https://github.com/openjdk/jdk into doc/owner-type
>  - Cleanup
>  - ... and 7 more: https://git.openjdk.org/jdk/compare/878b88cd...4f4d9b91

I have updated the CR preview and did some minor updates; please review again.

-------------

PR Comment: https://git.openjdk.org/jdk/pull/19977#issuecomment-2689045628

Reply via email to