mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-25 13:19:21 +08:00 
			
		
		
		
	Make TerminalView agnostic of "termux.properties" files.
`TerminalView` will use the `TerminalViewClient` interface implemented by `TermuxViewClient` in termux-app to get "enforce-char-based-input" and "ctrl-space-workaround" property values. It will also not read the file every time it needs to get the property value and will get it from the in-memory cache of `TermuxSharedProperties`.
This commit is contained in:
		| @@ -52,6 +52,16 @@ public final class TermuxViewClient implements TerminalViewClient { | ||||
|         return mActivity.mProperties.isBackKeyTheEscapeKey(); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public boolean shouldEnforeCharBasedInput() { | ||||
|         return mActivity.mProperties.isEnforcingCharBasedInput(); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public boolean shouldUseCtrlSpaceWorkaround() { | ||||
|         return mActivity.mProperties.isUsingCtrlSpaceWorkaround(); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void copyModeChanged(boolean copyMode) { | ||||
|         // Disable drawer while copying. | ||||
|   | ||||
| @@ -61,11 +61,22 @@ public final class TermuxPropertyConstants { | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for whether to enforce character based input to fix the issue where for some devices like Samsung, the letters might not appear until enter is pressed */ | ||||
|     public static final String KEY_ENFORCE_CHAR_BASED_INPUT =  "enforce-char-based-input"; // Default: "enforce-char-based-input" | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for whether to use black UI */ | ||||
|     public static final String KEY_USE_BLACK_UI =  "use-black-ui"; // Default: "use-black-ui" | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for whether to use ctrl space workaround to fix the issue where ctrl+space does not work on some ROMs */ | ||||
|     public static final String KEY_USE_CTRL_SPACE_WORKAROUND =  "ctrl-space-workaround"; // Default: "ctrl-space-workaround" | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for whether to use fullscreen */ | ||||
|     public static final String KEY_USE_FULLSCREEN =  "fullscreen"; // Default: "fullscreen" | ||||
|  | ||||
| @@ -155,8 +166,10 @@ public final class TermuxPropertyConstants { | ||||
|      * */ | ||||
|     public static final Set<String> TERMUX_PROPERTIES_LIST = new HashSet<>(Arrays.asList( | ||||
|         // boolean | ||||
|         KEY_ENFORCE_CHAR_BASED_INPUT, | ||||
|         KEY_USE_BACK_KEY_AS_ESCAPE_KEY, | ||||
|         KEY_USE_BLACK_UI, | ||||
|         KEY_USE_CTRL_SPACE_WORKAROUND, | ||||
|         KEY_USE_FULLSCREEN, | ||||
|         KEY_USE_FULLSCREEN_WORKAROUND, | ||||
|         KEY_VIRTUAL_VOLUME_KEYS_DISABLED, | ||||
| @@ -183,6 +196,8 @@ public final class TermuxPropertyConstants { | ||||
|      * default: false | ||||
|      * */ | ||||
|     public static final Set<String> TERMUX_DEFAULT_BOOLEAN_BEHAVIOUR_PROPERTIES_LIST = new HashSet<>(Arrays.asList( | ||||
|         KEY_ENFORCE_CHAR_BASED_INPUT, | ||||
|         KEY_USE_CTRL_SPACE_WORKAROUND, | ||||
|         KEY_USE_FULLSCREEN, | ||||
|         KEY_USE_FULLSCREEN_WORKAROUND, | ||||
|         TermuxConstants.PROP_ALLOW_EXTERNAL_APPS | ||||
|   | ||||
| @@ -485,6 +485,10 @@ public class TermuxSharedProperties implements SharedPropertiesParser { | ||||
|  | ||||
|  | ||||
|  | ||||
|     public boolean isEnforcingCharBasedInput() { | ||||
|         return (boolean) getInternalPropertyValue(TermuxPropertyConstants.KEY_ENFORCE_CHAR_BASED_INPUT, true); | ||||
|     } | ||||
|  | ||||
|     public boolean isBackKeyTheEscapeKey() { | ||||
|         return (boolean) getInternalPropertyValue(TermuxPropertyConstants.KEY_USE_BACK_KEY_AS_ESCAPE_KEY, true); | ||||
|     } | ||||
| @@ -493,6 +497,10 @@ public class TermuxSharedProperties implements SharedPropertiesParser { | ||||
|         return (boolean) getInternalPropertyValue(TermuxPropertyConstants.KEY_USE_BLACK_UI, true); | ||||
|     } | ||||
|  | ||||
|     public boolean isUsingCtrlSpaceWorkaround() { | ||||
|         return (boolean) getInternalPropertyValue(TermuxPropertyConstants.KEY_USE_CTRL_SPACE_WORKAROUND, true); | ||||
|     } | ||||
|  | ||||
|     public boolean isUsingFullScreen() { | ||||
|         return (boolean) getInternalPropertyValue(TermuxPropertyConstants.KEY_USE_FULLSCREEN, true); | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user