I have a small Android application in which I point my application directly and make some application-level settings in onSreate ApplicationSubclass, but I get the following error (note, I know about FLAG_ACTIVITY_NEW_TASK):
Caused by: android.util.AndroidRuntimeException: Calling startActivity() from outside of an Activity context requires the FLAG_ACTIVITY_NEW_TASK flag. Is this really what you want? at android.app.ContextImpl.startActivity(ContextImpl.java:644) at android.content.ContextWrapper.startActivity(ContextWrapper.java:258) at somePart.ofA.nameSpace.ApplicationSubclass.sendNotificationEmail(ApplicationSubclass.java:186)
I call this sendNotificationEmail when several exceptions are thrown, and I catch them, so that the application user can send a small email with information about the exception so that I can more easily fix anything that might occur, or direct them to fix their problem.
Here are some of the relevant code:
manifest.xml:
<application android:label="@string/app_name" android:icon="@drawable/icon" android:name=".ApplicationSubclass"> // ... some stuff, including all of my app activities </application>
ApplicationSubclass is defined as:
public class ApplicationSubclass extends Application {
I would like to know why this is happening. I read some documentation, I searched for some answers on StackOverflow and the Internet in general. It seems to me that I should be fine, as I set FLAG_ACTIVITY_NEW_TASK, however this is clearly not the case!
Is it just that I can't even do this from the context of the application? Should I be within the scope of the Activity in my application when I try to do this? It would be very unpleasant that it would be necessary to rearrange around this, and the ability to send exceptions emails would be very useful!
EDIT : Rich asked a good question, and why the hell do I want to do this first? The answer is that there is data in the application that may be crashing, and I would like the user to be able to send some of this crash data when this happens.
The reason for this in the application, and not in the action, is that there are application state variables that I donβt want to lose every time someone turns the device on. When I found out that onPause and onCreate are called on rotation (for Activies), I reorganized this code into an application (which works great!). I actually tried the solution of sending them to onConfigurationChanged and overriding this method in my activity, but this is messy and for whatever reason, despite the fact that I put android:configChanges="keyboardHidden|orientation"
in my manifest, it didnβt work for me correctly. I am sure that I can pursue this option, but I would prefer to leave things as they are (it is cleaner) and get an opportunity for someone via email!