allow reflection metadata for classes that reference undefined classes #3037
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This is a fix for #2207
Native-image does not allow reflection registration of classes referencing undefined classes, for example in the case of optional dependencies in 3rd party libraries.
A simple example of this goes as follows: (copied from what I wrote here #2207 (comment))
file:
UndefinedReferencePoc.java
file:
reflect-config.json
Steps to reproduce:
javac UndefinedReferencePoc.java
DeleteMe.class
filenative-image -H:Name=UndefinedReferencePoc -H:Class=UndefinedReferencePoc --verbose --no-fallback --allow-incomplete-classpath -H:ReflectionConfigurationResources=reflect-config.json
This PR fixes this by splitting up the verification to only check fields/methods/constructors/classes if there is reflection config present for them.