1
0
Fork 0
mirror of https://github.com/syncthing/syncthing-android.git synced 2025-01-09 19:53:33 +00:00

Disable wakelock experimental option on Android 6+ (#77)

This commit is contained in:
Catfriend1 2018-10-07 18:28:46 +02:00 committed by GitHub
parent 466fc971dd
commit 2021ef6806
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 29 additions and 21 deletions

View file

@ -231,6 +231,12 @@ public class SettingsActivity extends SyncthingActivity {
mRunOnMeteredWifi.setEnabled(mRunOnWifi.isChecked()); mRunOnMeteredWifi.setEnabled(mRunOnWifi.isChecked());
mWifiSsidWhitelist.setEnabled(mRunOnWifi.isChecked()); mWifiSsidWhitelist.setEnabled(mRunOnWifi.isChecked());
/* Experimental options */
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
/* Wakelocks are only valid on Android 5 or lower. */
mUseWakelock.setEnabled(false);
mUseWakelock.setChecked(false);
}
mCategorySyncthingOptions = findPreference("category_syncthing_options"); mCategorySyncthingOptions = findPreference("category_syncthing_options");
setPreferenceCategoryChangeListener(mCategorySyncthingOptions, this::onSyncthingPreferenceChange); setPreferenceCategoryChangeListener(mCategorySyncthingOptions, this::onSyncthingPreferenceChange);

View file

@ -4,6 +4,7 @@ import android.annotation.SuppressLint;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.SharedPreferences; import android.content.SharedPreferences;
import android.os.Build;
import android.os.Environment; import android.os.Environment;
import android.os.PowerManager; import android.os.PowerManager;
import android.os.SystemClock; import android.os.SystemClock;
@ -133,13 +134,20 @@ public class SyncthingRunnable implements Runnable {
} catch (IOException | InterruptedException e) { } catch (IOException | InterruptedException e) {
Log.w(TAG, "Failed to chmod Syncthing", e); Log.w(TAG, "Failed to chmod Syncthing", e);
} }
// Loop Syncthing
/**
* Potential fix for #498, keep the CPU running while native binary is running.
* Only valid on Android 5 or lower.
*/
PowerManager pm;
PowerManager.WakeLock wakeLock = null;
Boolean useWakeLock = mPreferences.getBoolean(Constants.PREF_USE_WAKE_LOCK, false);
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M && useWakeLock) {
pm = (PowerManager) mContext.getSystemService(Context.POWER_SERVICE);
wakeLock = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, TAG);
}
Process process = null; Process process = null;
// Potential fix for #498, keep the CPU running while native binary is running
PowerManager pm = (PowerManager) mContext.getSystemService(Context.POWER_SERVICE);
PowerManager.WakeLock wakeLock = useWakeLock()
? pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, TAG)
: null;
try { try {
if (wakeLock != null) { if (wakeLock != null) {
wakeLock.acquire(); wakeLock.acquire();
@ -263,13 +271,6 @@ public class SyncthingRunnable implements Runnable {
} }
} }
/**
* Returns true if the experimental setting for using wake locks has been enabled in settings.
*/
private boolean useWakeLock() {
return mPreferences.getBoolean(Constants.PREF_USE_WAKE_LOCK, false);
}
/** /**
* Look for running libsyncthing.so processes and return an array * Look for running libsyncthing.so processes and return an array
* containing the PIDs of found instances. * containing the PIDs of found instances.

View file

@ -434,7 +434,7 @@ Bitte melden Sie auftretende Probleme via GitHub.</string>
<string name="keep_wakelock_while_binary_running">Prozessor wach halten während Syncthing läuft.</string> <string name="keep_wakelock_while_binary_running">Prozessor wach halten während Syncthing läuft.</string>
<string name="keep_wakelock_while_binary_running_summary">Nutze dieses Einstellung, wenn du unerwartete Verbindungsabbrüche hast, während du im Batteriebetrieb arbeitest. Das wird zu einem erhöhten Energieverbrauch führen.</string> <string name="keep_wakelock_while_binary_running_summary">Nur für Android 5 oder niedriger. Nutze diese Einstellung, wenn du unerwartete Verbindungsabbrüche hast, während du im Batteriebetrieb arbeitest. Das wird zu einem erhöhten Energieverbrauch führen.</string>
<string name="use_tor_title">Tor benutzen</string> <string name="use_tor_title">Tor benutzen</string>

View file

@ -438,7 +438,7 @@ Please report any problems you encounter via Github.</string>
<string name="keep_wakelock_while_binary_running">Keep the CPU awake while Syncthing is running</string> <string name="keep_wakelock_while_binary_running">Keep the CPU awake while Syncthing is running</string>
<string name="keep_wakelock_while_binary_running_summary">Use this setting if you experience unexpected disconnects while operating on battery. This will result in increased battery consumption.</string> <string name="keep_wakelock_while_binary_running_summary">Only for Android 5 or lower. Use this setting if you experience unexpected disconnects while operating on battery. This will result in increased battery consumption.</string>
<string name="use_tor_title">Use Tor</string> <string name="use_tor_title">Use Tor</string>

View file

@ -242,12 +242,6 @@
android:title="@string/category_experimental" android:title="@string/category_experimental"
android:key="category_experimental"> android:key="category_experimental">
<CheckBoxPreference
android:key="wakelock_while_binary_running"
android:title="@string/keep_wakelock_while_binary_running"
android:summary="@string/keep_wakelock_while_binary_running_summary"
android:defaultValue="false" />
<CheckBoxPreference <CheckBoxPreference
android:key="use_tor" android:key="use_tor"
android:title="@string/use_tor_title" android:title="@string/use_tor_title"
@ -270,6 +264,13 @@
android:title="@string/use_legacy_hashing_title" android:title="@string/use_legacy_hashing_title"
android:summary="@string/use_legacy_hashing_summary" /> android:summary="@string/use_legacy_hashing_summary" />
<!-- Only valid for Android < 6 -->
<CheckBoxPreference
android:key="wakelock_while_binary_running"
android:title="@string/keep_wakelock_while_binary_running"
android:summary="@string/keep_wakelock_while_binary_running_summary"
android:defaultValue="false" />
</PreferenceScreen> </PreferenceScreen>
<PreferenceScreen <PreferenceScreen