cordova-issues mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "ASF GitHub Bot (JIRA)" <j...@apache.org>
Subject [jira] [Commented] (CB-10472) NullPointerException: Attempt to invoke virtual method 'android.os.Bundle org.apache.cordova.PluginManager.onSaveInstanceState
Date Thu, 28 Jan 2016 21:00:42 GMT

    [ https://issues.apache.org/jira/browse/CB-10472?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15122302#comment-15122302
] 

ASF GitHub Bot commented on CB-10472:
-------------------------------------

GitHub user csantanapr opened a pull request:

    https://github.com/apache/cordova-android/pull/255

    CB-10472 NullPointerException: org.apache.cordova.PluginManager.onSav…

    …eInstanceState
    
    check if pluginManager is null before using it

You can merge this pull request into a Git repository by running:

    $ git pull https://github.com/csantanapr/cordova-android CB-10472

Alternatively you can review and apply these changes as the patch at:

    https://github.com/apache/cordova-android/pull/255.patch

To close this pull request, make a commit to your master/trunk branch
with (at least) the following in the commit message:

    This closes #255
    
----
commit 907e67d2b8dc13673271182555ab66a2564448af
Author: Carlos Santana <csantana23@gmail.com>
Date:   2016-01-28T20:57:38Z

    CB-10472 NullPointerException: org.apache.cordova.PluginManager.onSaveInstanceState
    check if pluginManager is null before using it

----


> NullPointerException: Attempt to invoke virtual method 'android.os.Bundle org.apache.cordova.PluginManager.onSaveInstanceState
> ------------------------------------------------------------------------------------------------------------------------------
>
>                 Key: CB-10472
>                 URL: https://issues.apache.org/jira/browse/CB-10472
>             Project: Apache Cordova
>          Issue Type: Bug
>          Components: Android
>    Affects Versions: 5.1.0
>         Environment: cordova-android 5.1.0
>            Reporter: Carlos Santana
>              Labels: android
>
> pluginManager not being check for null before using it in CordovaInterfaceImpl
> 01-28 14:24:10.396  27684-27684/io.cordova.hellocordova E/AndroidRuntime﹕ FATAL EXCEPTION:
main
>     Process: io.cordova.hellocordova, PID: 27684
>     java.lang.NullPointerException: Attempt to invoke virtual method 'android.os.Bundle
org.apache.cordova.PluginManager.onSaveInstanceState()' on a null object reference
>             at org.apache.cordova.CordovaInterfaceImpl.onSaveInstanceState(CordovaInterfaceImpl.java:173)
>             at org.apache.cordova.CordovaActivity.onSaveInstanceState(CordovaActivity.java:465)
>             at android.app.Activity.performSaveInstanceState(Activity.java:1298)
>             at android.app.Instrumentation.callActivityOnSaveInstanceState(Instrumentation.java:1288)
>             at android.app.ActivityThread.callCallActivityOnSaveInstanceState(ActivityThread.java:3958)
>             at android.app.ActivityThread.performStopActivityInner(ActivityThread.java:3369)
>             at android.app.ActivityThread.handleStopActivity(ActivityThread.java:3425)
>             at android.app.ActivityThread.access$1100(ActivityThread.java:151)
>             at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1332)
>             at android.os.Handler.dispatchMessage(Handler.java:102)
>             at android.os.Looper.loop(Looper.java:135)
>             at android.app.ActivityThread.main(ActivityThread.java:5254)
>             at java.lang.reflect.Method.invoke(Native Method)
>             at java.lang.reflect.Method.invoke(Method.java:372)
>             at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
>             at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
> Recreate
> cordova create testapp
> cd testapp
> cordova platform add android@5.1.0
> Modify MainActivity to launch a second Cordova Activity like this:
> change MainActivity.java
> Notice no init or loadUrl called, this is on purpose in our App for this use case we
want to avoid this, and let the second Activity to call loadUrl
> public class MainActivity extends CordovaActivity
> {
>     @Override
>     public void onCreate(Bundle savedInstanceState)
>     {
>         super.onCreate(savedInstanceState);
>     }
>     @Override
>     protected void onStart(){
>         super.onStart();
>         Intent newActivity = new Intent(this, MainActivity2.class);
>         startActivity(newActivity);
>     }
> }
> Add class io.cordova.hellocordova.MainActivity2.java
> public class MainActivity2 extends CordovaActivity
> {
>     @Override
>     public void onCreate(Bundle savedInstanceState)
>     {
>         super.onCreate(savedInstanceState);
>         // Set by <content src="index.html" /> in config.xml
>         loadUrl(launchUrl);
>     }
> }
> Add activity to AndroidManifest.xml
> <activity android:name="io.cordova.hellocordova.MainActivity2" />
> Since init() or loadUrl was never called in MainActivity, pluginManager never got created,
this let pluginManager be null



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

---------------------------------------------------------------------
To unsubscribe, e-mail: issues-unsubscribe@cordova.apache.org
For additional commands, e-mail: issues-help@cordova.apache.org


Mime
View raw message