mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-25 21:29:20 +08:00 
			
		
		
		
	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:
		| @@ -18,6 +18,7 @@ public class TermuxAPIAppSharedPreferences { | ||||
|  | ||||
|     private final Context mContext; | ||||
|     private final SharedPreferences mSharedPreferences; | ||||
|     private final SharedPreferences mMultiProcessSharedPreferences; | ||||
|  | ||||
|  | ||||
|     private static final String LOG_TAG = "TermuxAPIAppSharedPreferences"; | ||||
| @@ -25,6 +26,7 @@ public class TermuxAPIAppSharedPreferences { | ||||
|     private TermuxAPIAppSharedPreferences(@Nonnull Context context) { | ||||
|         mContext = context; | ||||
|         mSharedPreferences = getPrivateSharedPreferences(mContext); | ||||
|         mMultiProcessSharedPreferences = getPrivateAndMultiProcessSharedPreferences(mContext); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -65,15 +67,23 @@ public class TermuxAPIAppSharedPreferences { | ||||
|         return SharedPreferenceUtils.getPrivateSharedPreferences(context, TermuxConstants.TERMUX_API_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|  | ||||
|  | ||||
|     public int getLogLevel() { | ||||
|         return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_API_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     private static SharedPreferences getPrivateAndMultiProcessSharedPreferences(Context context) { | ||||
|         if (context == null) return null; | ||||
|         return SharedPreferenceUtils.getPrivateAndMultiProcessSharedPreferences(context, TermuxConstants.TERMUX_API_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel) { | ||||
|  | ||||
|  | ||||
|     public int getLogLevel(boolean readFromFile) { | ||||
|         if (readFromFile) | ||||
|             return SharedPreferenceUtils.getInt(mMultiProcessSharedPreferences, TERMUX_API_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|         else | ||||
|             return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_API_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel, boolean commitToFile) { | ||||
|         logLevel = Logger.setLogLevel(context, logLevel); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_API_APP.KEY_LOG_LEVEL, logLevel, false); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_API_APP.KEY_LOG_LEVEL, logLevel, commitToFile); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -18,6 +18,7 @@ public class TermuxBootAppSharedPreferences { | ||||
|  | ||||
|     private final Context mContext; | ||||
|     private final SharedPreferences mSharedPreferences; | ||||
|     private final SharedPreferences mMultiProcessSharedPreferences; | ||||
|  | ||||
|  | ||||
|     private static final String LOG_TAG = "TermuxBootAppSharedPreferences"; | ||||
| @@ -25,6 +26,7 @@ public class TermuxBootAppSharedPreferences { | ||||
|     private TermuxBootAppSharedPreferences(@Nonnull Context context) { | ||||
|         mContext = context; | ||||
|         mSharedPreferences = getPrivateSharedPreferences(mContext); | ||||
|         mMultiProcessSharedPreferences = getPrivateAndMultiProcessSharedPreferences(mContext); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -65,15 +67,23 @@ public class TermuxBootAppSharedPreferences { | ||||
|         return SharedPreferenceUtils.getPrivateSharedPreferences(context, TermuxConstants.TERMUX_BOOT_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|  | ||||
|  | ||||
|     public int getLogLevel() { | ||||
|         return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_BOOT_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     private static SharedPreferences getPrivateAndMultiProcessSharedPreferences(Context context) { | ||||
|         if (context == null) return null; | ||||
|         return SharedPreferenceUtils.getPrivateAndMultiProcessSharedPreferences(context, TermuxConstants.TERMUX_BOOT_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel) { | ||||
|  | ||||
|  | ||||
|     public int getLogLevel(boolean readFromFile) { | ||||
|         if (readFromFile) | ||||
|             return SharedPreferenceUtils.getInt(mMultiProcessSharedPreferences, TERMUX_BOOT_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|         else | ||||
|             return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_BOOT_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel, boolean commitToFile) { | ||||
|         logLevel = Logger.setLogLevel(context, logLevel); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_BOOT_APP.KEY_LOG_LEVEL, logLevel, false); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_BOOT_APP.KEY_LOG_LEVEL, logLevel, commitToFile); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -18,6 +18,7 @@ public class TermuxStylingAppSharedPreferences { | ||||
|  | ||||
|     private final Context mContext; | ||||
|     private final SharedPreferences mSharedPreferences; | ||||
|     private final SharedPreferences mMultiProcessSharedPreferences; | ||||
|  | ||||
|  | ||||
|     private static final String LOG_TAG = "TermuxStylingAppSharedPreferences"; | ||||
| @@ -25,6 +26,7 @@ public class TermuxStylingAppSharedPreferences { | ||||
|     private TermuxStylingAppSharedPreferences(@Nonnull Context context) { | ||||
|         mContext = context; | ||||
|         mSharedPreferences = getPrivateSharedPreferences(mContext); | ||||
|         mMultiProcessSharedPreferences = getPrivateAndMultiProcessSharedPreferences(mContext); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -65,15 +67,23 @@ public class TermuxStylingAppSharedPreferences { | ||||
|         return SharedPreferenceUtils.getPrivateSharedPreferences(context, TermuxConstants.TERMUX_STYLING_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|  | ||||
|  | ||||
|     public int getLogLevel() { | ||||
|         return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_STYLING_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     private static SharedPreferences getPrivateAndMultiProcessSharedPreferences(Context context) { | ||||
|         if (context == null) return null; | ||||
|         return SharedPreferenceUtils.getPrivateAndMultiProcessSharedPreferences(context, TermuxConstants.TERMUX_STYLING_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel) { | ||||
|  | ||||
|  | ||||
|     public int getLogLevel(boolean readFromFile) { | ||||
|         if (readFromFile) | ||||
|             return SharedPreferenceUtils.getInt(mMultiProcessSharedPreferences, TERMUX_STYLING_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|         else | ||||
|             return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_STYLING_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel, boolean commitToFile) { | ||||
|         logLevel = Logger.setLogLevel(context, logLevel); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_STYLING_APP.KEY_LOG_LEVEL, logLevel, false); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_STYLING_APP.KEY_LOG_LEVEL, logLevel, commitToFile); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -18,6 +18,7 @@ public class TermuxWidgetAppSharedPreferences { | ||||
|  | ||||
|     private final Context mContext; | ||||
|     private final SharedPreferences mSharedPreferences; | ||||
|     private final SharedPreferences mMultiProcessSharedPreferences; | ||||
|  | ||||
|  | ||||
|     private static final String LOG_TAG = "TermuxWidgetAppSharedPreferences"; | ||||
| @@ -25,6 +26,7 @@ public class TermuxWidgetAppSharedPreferences { | ||||
|     private TermuxWidgetAppSharedPreferences(@Nonnull Context context) { | ||||
|         mContext = context; | ||||
|         mSharedPreferences = getPrivateSharedPreferences(mContext); | ||||
|         mMultiProcessSharedPreferences = getPrivateAndMultiProcessSharedPreferences(mContext); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -65,15 +67,23 @@ public class TermuxWidgetAppSharedPreferences { | ||||
|         return SharedPreferenceUtils.getPrivateSharedPreferences(context, TermuxConstants.TERMUX_WIDGET_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|  | ||||
|  | ||||
|     public int getLogLevel() { | ||||
|         return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_WIDGET_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     private static SharedPreferences getPrivateAndMultiProcessSharedPreferences(Context context) { | ||||
|         if (context == null) return null; | ||||
|         return SharedPreferenceUtils.getPrivateAndMultiProcessSharedPreferences(context, TermuxConstants.TERMUX_WIDGET_DEFAULT_PREFERENCES_FILE_BASENAME_WITHOUT_EXTENSION); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel) { | ||||
|  | ||||
|  | ||||
|     public int getLogLevel(boolean readFromFile) { | ||||
|         if (readFromFile) | ||||
|             return SharedPreferenceUtils.getInt(mMultiProcessSharedPreferences, TERMUX_WIDGET_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|         else | ||||
|             return SharedPreferenceUtils.getInt(mSharedPreferences, TERMUX_WIDGET_APP.KEY_LOG_LEVEL, Logger.DEFAULT_LOG_LEVEL); | ||||
|     } | ||||
|  | ||||
|     public void setLogLevel(Context context, int logLevel, boolean commitToFile) { | ||||
|         logLevel = Logger.setLogLevel(context, logLevel); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_WIDGET_APP.KEY_LOG_LEVEL, logLevel, false); | ||||
|         SharedPreferenceUtils.setInt(mSharedPreferences, TERMUX_WIDGET_APP.KEY_LOG_LEVEL, logLevel, commitToFile); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user