mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-07 05:24:46 +01:00
fix crashes (NPE and RelayService trying to run in background)
Still need to figure out what RelayService does. It needn't run for long except where GCM isn't present.
This commit is contained in:
parent
eb6831ea12
commit
88fe2739c1
3 changed files with 28 additions and 10 deletions
|
@ -234,7 +234,8 @@ public class BTService extends XWService {
|
||||||
|
|
||||||
private static void onAppStateChange( Context context, boolean inForeground )
|
private static void onAppStateChange( Context context, boolean inForeground )
|
||||||
{
|
{
|
||||||
if ( sInForeground == null || sInForeground != inForeground ) {
|
Log.d( TAG, "onAppStateChange(inForeground=%b)", inForeground );
|
||||||
|
if ( null == sInForeground || inForeground() != inForeground ) {
|
||||||
sInForeground = inForeground;
|
sInForeground = inForeground;
|
||||||
|
|
||||||
Intent intent =
|
Intent intent =
|
||||||
|
@ -245,6 +246,11 @@ public class BTService extends XWService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static boolean inForeground()
|
||||||
|
{
|
||||||
|
return sInForeground != null && sInForeground;
|
||||||
|
}
|
||||||
|
|
||||||
static void onAppToForeground( Context context )
|
static void onAppToForeground( Context context )
|
||||||
{
|
{
|
||||||
onAppStateChange( context, true );
|
onAppStateChange( context, true );
|
||||||
|
@ -348,14 +354,17 @@ public class BTService extends XWService {
|
||||||
|
|
||||||
private static void startService( Context context, Intent intent )
|
private static void startService( Context context, Intent intent )
|
||||||
{
|
{
|
||||||
Log.d( TAG, "startService(%s)", intent );
|
boolean inForeground = inForeground();
|
||||||
|
Log.d( TAG, "startService(%s); inForeground = %b", intent, inForeground );
|
||||||
|
|
||||||
if ( ! sInForeground && canRunForegroundService() ) {
|
if ( ! inForeground && canRunForegroundService() ) {
|
||||||
if ( XWPrefs.getBTBackgroundEnabled( context ) ) {
|
if ( XWPrefs.getBTBackgroundEnabled( context ) ) {
|
||||||
context.startForegroundService( intent );
|
context.startForegroundService( intent );
|
||||||
}
|
}
|
||||||
} else if ( sInForeground || Build.VERSION.SDK_INT < Build.VERSION_CODES.O ) {
|
} else if ( inForeground || Build.VERSION.SDK_INT < Build.VERSION_CODES.O ) {
|
||||||
context.startService( intent );
|
context.startService( intent );
|
||||||
|
} else {
|
||||||
|
Log.d( TAG, "startService(); not starting" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -399,7 +408,7 @@ public class BTService extends XWService {
|
||||||
{
|
{
|
||||||
int result = handleCommand( intent );
|
int result = handleCommand( intent );
|
||||||
|
|
||||||
if ( Service.START_STICKY == result && !sInForeground ) {
|
if ( Service.START_STICKY == result && ! inForeground() ) {
|
||||||
startForeground();
|
startForeground();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -514,7 +523,7 @@ public class BTService extends XWService {
|
||||||
.setContentIntent(pendIntent)
|
.setContentIntent(pendIntent)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
Log.d( TAG, "calling startForeground()" );
|
Log.d( TAG, "calling service.startForeground()" );
|
||||||
startForeground( 1337, notification );
|
startForeground( 1337, notification );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -30,10 +30,12 @@ public class OnBootReceiver extends BroadcastReceiver {
|
||||||
@Override
|
@Override
|
||||||
public void onReceive( Context context, Intent intent )
|
public void onReceive( Context context, Intent intent )
|
||||||
{
|
{
|
||||||
if ( null != intent && null != intent.getAction()
|
if ( null != intent
|
||||||
|
&& null != intent.getAction()
|
||||||
&& intent.getAction().equals( Intent.ACTION_BOOT_COMPLETED ) ) {
|
&& intent.getAction().equals( Intent.ACTION_BOOT_COMPLETED ) ) {
|
||||||
Log.d( TAG, "got ACTION_BOOT_COMPLETED" );
|
Log.d( TAG, "got ACTION_BOOT_COMPLETED" );
|
||||||
startTimers( context );
|
startTimers( context );
|
||||||
|
BTService.onAppToBackground( context );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -77,6 +77,8 @@ public class RelayService extends XWService
|
||||||
|
|
||||||
private static final String CMD_STR = "CMD";
|
private static final String CMD_STR = "CMD";
|
||||||
|
|
||||||
|
private static Boolean sInForeground;
|
||||||
|
|
||||||
private static enum MsgCmds { INVALID,
|
private static enum MsgCmds { INVALID,
|
||||||
PROCESS_GAME_MSGS,
|
PROCESS_GAME_MSGS,
|
||||||
PROCESS_DEV_MSGS,
|
PROCESS_DEV_MSGS,
|
||||||
|
@ -188,6 +190,11 @@ public class RelayService extends XWService
|
||||||
enabledChanged( context );
|
enabledChanged( context );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static boolean inForeground()
|
||||||
|
{
|
||||||
|
return sInForeground != null && sInForeground;
|
||||||
|
}
|
||||||
|
|
||||||
public static void startService( Context context )
|
public static void startService( Context context )
|
||||||
{
|
{
|
||||||
Log.i( TAG, "startService()" );
|
Log.i( TAG, "startService()" );
|
||||||
|
@ -199,10 +206,10 @@ public class RelayService extends XWService
|
||||||
{
|
{
|
||||||
Log.d( TAG, "startService(%s)", intent );
|
Log.d( TAG, "startService(%s)", intent );
|
||||||
|
|
||||||
if ( false ) {
|
if ( inForeground() || Build.VERSION.SDK_INT < Build.VERSION_CODES.O ) {
|
||||||
context.startForegroundService( intent );
|
|
||||||
} else {
|
|
||||||
context.startService( intent );
|
context.startService( intent );
|
||||||
|
} else {
|
||||||
|
Log.d( TAG, "startService(); not starting" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue