From 448d3ae68c4ecef4f12a5f3974c38bf4d0f1a272 Mon Sep 17 00:00:00 2001 From: Niklas Baudy Date: Tue, 7 Jan 2025 10:37:03 +0800 Subject: [PATCH] Include traces in exception message to possibly hint why it failed. --- .../com/vanniktech/rxpermission/RealRxPermission.java | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/rxpermission/src/main/java/com/vanniktech/rxpermission/RealRxPermission.java b/rxpermission/src/main/java/com/vanniktech/rxpermission/RealRxPermission.java index e6049a8..9158b8e 100644 --- a/rxpermission/src/main/java/com/vanniktech/rxpermission/RealRxPermission.java +++ b/rxpermission/src/main/java/com/vanniktech/rxpermission/RealRxPermission.java @@ -37,6 +37,8 @@ public final class RealRxPermission implements RxPermission { static final String PREF_REQUESTED_PERMISSIONS = "requested-permissions"; + static final StringBuffer TRACES = new StringBuffer(); + /** * @param context any context * @return a Singleton instance of this class @@ -44,6 +46,7 @@ public final class RealRxPermission implements RxPermission { public static RealRxPermission getInstance(final Context context) { synchronized (RealRxPermission.class) { if (instance == null) { + TRACES.append("created new instance -> "); instance = new RealRxPermission((Application) context.getApplicationContext()); } } @@ -131,7 +134,10 @@ public static RealRxPermission getInstance(final Context context) { if (subject == null) { unrequestedPermissions.add(permission); subject = PublishSubject.create(); + TRACES.append("putting ").append(permission).append(" -> "); currentPermissionRequests.put(permission, subject); + } else { + TRACES.append("obtained ").append(permission).append(" -> "); } list.add(subject); @@ -190,10 +196,11 @@ void onRequestPermissionsResult(@NonNull final int[] grantResults, @NonNull fina for (int i = 0; i < size; i++) { final String permission = permissions[i]; + TRACES.append("removing ").append(permission).append(" -> "); final PublishSubject subject = currentPermissionRequests.remove(permission); if (subject == null) { - throw new IllegalStateException("RealRxPermission.onRequestPermissionsResult invoked but didn't find the corresponding permission request for " + permission); + throw new IllegalStateException("RealRxPermission.onRequestPermissionsResult invoked but didn't find the corresponding permission request for " + permission + " debug logs: " + TRACES); } final boolean granted = grantResults[i] == PERMISSION_GRANTED; @@ -215,6 +222,7 @@ void onRequestPermissionsResult(@NonNull final int[] grantResults, @NonNull fina } void cancelPermissionsRequests() { + TRACES.append("cancelPermissionsRequests -> "); currentPermissionRequests.clear(); }