Changed: Use multi-process SharedPrefernces for log level of plugin apps

Since termux-app runs in a separate process from other apps, if a user sets log level in termux settings, then it would require exiting the `termux-app` completely since android caches `SharedPrefernces` in memory and only writes to the file on app exit. Now updated value will be instantly written to the file so that plugins can directly read at startup. If plugins are already running, they would need to be restarted since usually log levels are loaded at startup.
This commit is contained in:
agnostic-apollo
2021-09-02 06:40:02 +05:00
parent d55c1001c8
commit 9f1203f049
5 changed files with 67 additions and 27 deletions

View File

@@ -41,7 +41,7 @@ public class DebuggingPreferencesFragment extends PreferenceFragmentCompat {
if (preferences == null) return;
com.termux.app.fragments.settings.termux.DebuggingPreferencesFragment.
setLogLevelListPreferenceData(logLevelListPreference, context, preferences.getLogLevel());
setLogLevelListPreferenceData(logLevelListPreference, context, preferences.getLogLevel(true));
loggingCategory.addPreference(logLevelListPreference);
}
}
@@ -76,7 +76,7 @@ class DebuggingPreferencesDataStore extends PreferenceDataStore {
switch (key) {
case "log_level":
return String.valueOf(mPreferences.getLogLevel());
return String.valueOf(mPreferences.getLogLevel(true));
default:
return null;
}
@@ -90,7 +90,7 @@ class DebuggingPreferencesDataStore extends PreferenceDataStore {
switch (key) {
case "log_level":
if (value != null) {
mPreferences.setLogLevel(mContext, Integer.parseInt(value));
mPreferences.setLogLevel(mContext, Integer.parseInt(value), true);
}
break;
default: