Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix for crash on AndroidX #560

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

themockgraeme
Copy link

Eventbus is crashing when my app is running on a device with an API level below 26 and using the AndroidX libraries.

The problem is that a NoClassDefFoundError is being thrown for the TextClassifier that's a parameter in the AppCompatTextView#setTextClassifier() method. The reflection code you use doesn't filter for API level, unfortunately.

A quick fix is to add "androidx." to the system classes in the moveToSuperClass() method. You should probably do this for performance reasons in any case.

Eventbus is crashing when my app is running on a device with an API level below 26 and using the AndroidX libraries.

The problem is that a NoClassDefFoundError is being thrown for the TextClassifier that's a parameter in the AppCompatTextView#setTextClassifier() method. The reflection code you use doesn't filter for API level, unfortunately.

A quick fix is to add "androidx." to the system classes in the moveToSuperClass() method. You should probably do this for performance reasons in any case.
The EventBus API will crash if it runs into a method that takes a parameter that the app doesn't recognise. Android gets around this using the @TargetAPI annotation, but this requires a minimum API level of 15.

The easiest way to fix this is reverse the order of checking the number of parameters a method takes and whether the Subscribe annotation is present. This means the getParameterTypes() call is deferred, and if a system library incorporates something not available on a given API level, it won't find an unknown type.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant