diff options
author | Martijn Coenen <maco@google.com> | 2012-01-10 14:41:42 -0800 |
---|---|---|
committer | Martijn Coenen <maco@google.com> | 2012-01-10 14:52:15 -0800 |
commit | 1668f533e6a2f041703919bafa4c3ceee62dbc38 (patch) | |
tree | 59697c7ebfa6ca43534ecb4b50b93a52595b7938 /src/com/android/nfc | |
parent | 128f32befd09c124cbede2dad169824abd44cdf9 (diff) | |
download | packages_apps_nfc-1668f533e6a2f041703919bafa4c3ceee62dbc38.zip packages_apps_nfc-1668f533e6a2f041703919bafa4c3ceee62dbc38.tar.gz packages_apps_nfc-1668f533e6a2f041703919bafa4c3ceee62dbc38.tar.bz2 |
Make airplane override for NFC persistent.
Make behavior identical to wifi/bluetooth.
Bug: 5455123
Change-Id: I8c10888b7d3129723c6520dc0e81fa1793ae542c
Diffstat (limited to 'src/com/android/nfc')
-rwxr-xr-x | src/com/android/nfc/NfcService.java | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/src/com/android/nfc/NfcService.java b/src/com/android/nfc/NfcService.java index 2ec937e..7fef485 100755 --- a/src/com/android/nfc/NfcService.java +++ b/src/com/android/nfc/NfcService.java @@ -97,6 +97,7 @@ public class NfcService extends Application implements DeviceHostListener { static final boolean NDEF_PUSH_ON_DEFAULT = true; static final String PREF_FIRST_BEAM = "first_beam"; static final String PREF_FIRST_BOOT = "first_boot"; + static final String PREF_AIRPLANE_OVERRIDE = "airplane_override"; static final boolean PN544_QUIRK_DISCONNECT_BEFORE_RECONFIGURE = true; @@ -457,8 +458,9 @@ public class NfcService extends Application implements DeviceHostListener { break; case TASK_BOOT: Log.d(TAG,"checking on firmware download"); + boolean airplaneOverride = mPrefs.getBoolean(PREF_AIRPLANE_OVERRIDE, false); if (mPrefs.getBoolean(PREF_NFC_ON, NFC_ON_DEFAULT) && - !(mIsAirplaneSensitive && isAirplaneModeOn())) { + (!mIsAirplaneSensitive || !isAirplaneModeOn() || airplaneOverride)) { Log.d(TAG,"NFC is on. Doing normal stuff"); enableInternal(); } else { @@ -647,9 +649,15 @@ public class NfcService extends Application implements DeviceHostListener { NfcService.enforceAdminPerm(mContext); saveNfcOnSetting(true); - if (mIsAirplaneSensitive && isAirplaneModeOn() && !mIsAirplaneToggleable) { - Log.i(TAG, "denying enable() request (airplane mode)"); - return false; + + if (mIsAirplaneSensitive && isAirplaneModeOn()) { + if (!mIsAirplaneToggleable) { + Log.i(TAG, "denying enable() request (airplane mode)"); + return false; + } + // Make sure the override survives a reboot + mPrefsEditor.putBoolean(PREF_AIRPLANE_OVERRIDE, true); + mPrefsEditor.apply(); } new EnableDisableTask().execute(TASK_ENABLE); @@ -1825,6 +1833,8 @@ public class NfcService extends Application implements DeviceHostListener { if (!mIsAirplaneSensitive) { return; } + mPrefsEditor.putBoolean(PREF_AIRPLANE_OVERRIDE, false); + mPrefsEditor.apply(); if (isAirplaneModeOn) { new EnableDisableTask().execute(TASK_DISABLE); } else if (!isAirplaneModeOn && mPrefs.getBoolean(PREF_NFC_ON, NFC_ON_DEFAULT)) { |