mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-25 13:19:21 +08:00 
			
		
		
		
	Allow users to set terminal cursor style with termux.properties
This `terminal-cursor-style` key can be used to set the terminal cursor style. The user can set a string value to `block` for `■`, `underline` for `_` or `bar` for `|` cursor style. The default value is still `block`. So adding an entry like `terminal-cursor-style=bar` to `termux.properties` file will allow users to change to the `bar` cursor style. After updating the value, termux must be restarted. You can also run `termux-reload-settings` command so that termux loads the updated value, but only new sessions will use the updated value, existing sessions will not be affected unless you Reset them from terminal's long hold options menu `More` -> `Reset` or restart termux activity after double back press to exit. You can temporarily switch to different cursor styles with (or add to `.bashrc` but resetting will restore default `bar` style): - block: `echo -e "\033[2 q"` - underline: `echo -e "\033[4 q"` - bar: ` echo -e "\033[6 q"` Closes #2075
This commit is contained in:
		| @@ -12,7 +12,7 @@ import java.util.HashSet; | ||||
| import java.util.Set; | ||||
|  | ||||
| /* | ||||
|  * Version: v0.11.0 | ||||
|  * Version: v0.12.0 | ||||
|  * | ||||
|  * Changelog | ||||
|  * | ||||
| @@ -53,6 +53,8 @@ import java.util.Set; | ||||
|  * - 0.11.0 (2021-06-10) | ||||
|  *      - Add `*KEY_TERMINAL_TRANSCRIPT_ROWS*`. | ||||
|  * | ||||
|  * - 0.12.0 (2021-06-10) | ||||
|  *      - Add `*KEY_TERMINAL_CURSOR_STYLE*`. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
| @@ -135,6 +137,28 @@ public final class TermuxPropertyConstants { | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for the terminal cursor style */ | ||||
|     public static final String KEY_TERMINAL_CURSOR_STYLE =  "terminal-cursor-style"; // Default: "terminal-cursor-style" | ||||
|  | ||||
|     public static final String VALUE_TERMINAL_CURSOR_STYLE_BLOCK = "block"; | ||||
|     public static final String VALUE_TERMINAL_CURSOR_STYLE_UNDERLINE = "underline"; | ||||
|     public static final String VALUE_TERMINAL_CURSOR_STYLE_BAR = "bar"; | ||||
|  | ||||
|     public static final int IVALUE_TERMINAL_CURSOR_STYLE_BLOCK = TerminalEmulator.TERMINAL_CURSOR_STYLE_BLOCK; | ||||
|     public static final int IVALUE_TERMINAL_CURSOR_STYLE_UNDERLINE = TerminalEmulator.TERMINAL_CURSOR_STYLE_UNDERLINE; | ||||
|     public static final int IVALUE_TERMINAL_CURSOR_STYLE_BAR = TerminalEmulator.TERMINAL_CURSOR_STYLE_BAR; | ||||
|     public static final int DEFAULT_IVALUE_TERMINAL_CURSOR_STYLE = TerminalEmulator.DEFAULT_TERMINAL_CURSOR_STYLE; | ||||
|  | ||||
|     /** Defines the bidirectional map for terminal cursor styles and their internal values */ | ||||
|     public static final ImmutableBiMap<String, Integer> MAP_TERMINAL_CURSOR_STYLE = | ||||
|         new ImmutableBiMap.Builder<String, Integer>() | ||||
|             .put(VALUE_TERMINAL_CURSOR_STYLE_BLOCK, IVALUE_TERMINAL_CURSOR_STYLE_BLOCK) | ||||
|             .put(VALUE_TERMINAL_CURSOR_STYLE_UNDERLINE, IVALUE_TERMINAL_CURSOR_STYLE_UNDERLINE) | ||||
|             .put(VALUE_TERMINAL_CURSOR_STYLE_BAR, IVALUE_TERMINAL_CURSOR_STYLE_BAR) | ||||
|             .build(); | ||||
|  | ||||
|  | ||||
|  | ||||
|     /** Defines the key for the terminal transcript rows */ | ||||
|     public static final String KEY_TERMINAL_TRANSCRIPT_ROWS =  "terminal-transcript-rows"; // Default: "terminal-transcript-rows" | ||||
|     public static final int IVALUE_TERMINAL_TRANSCRIPT_ROWS_MIN = TerminalEmulator.TERMINAL_TRANSCRIPT_ROWS_MIN; | ||||
| @@ -271,6 +295,7 @@ public final class TermuxPropertyConstants { | ||||
|         /* int */ | ||||
|         KEY_BELL_BEHAVIOUR, | ||||
|         KEY_TERMINAL_CURSOR_BLINK_RATE, | ||||
|         KEY_TERMINAL_CURSOR_STYLE, | ||||
|         KEY_TERMINAL_TRANSCRIPT_ROWS, | ||||
|  | ||||
|         /* float */ | ||||
|   | ||||
| @@ -217,6 +217,8 @@ public class TermuxSharedProperties { | ||||
|                 return (int) getBellBehaviourInternalPropertyValueFromValue(value); | ||||
|             case TermuxPropertyConstants.KEY_TERMINAL_CURSOR_BLINK_RATE: | ||||
|                 return (int) getTerminalCursorBlinkRateInternalPropertyValueFromValue(value); | ||||
|             case TermuxPropertyConstants.KEY_TERMINAL_CURSOR_STYLE: | ||||
|                 return (int) getTerminalCursorStyleInternalPropertyValueFromValue(value); | ||||
|             case TermuxPropertyConstants.KEY_TERMINAL_TRANSCRIPT_ROWS: | ||||
|                 return (int) getTerminalTranscriptRowsInternalPropertyValueFromValue(value); | ||||
|  | ||||
| @@ -277,7 +279,7 @@ public class TermuxSharedProperties { | ||||
|     /** | ||||
|      * Returns the internal value after mapping it based on | ||||
|      * {@code TermuxPropertyConstants#MAP_BELL_BEHAVIOUR} if the value is not {@code null} | ||||
|      * and is valid, otherwise returns {@code TermuxPropertyConstants#DEFAULT_IVALUE_BELL_BEHAVIOUR}. | ||||
|      * and is valid, otherwise returns {@link TermuxPropertyConstants#DEFAULT_IVALUE_BELL_BEHAVIOUR}. | ||||
|      * | ||||
|      * @param value The {@link String} value to convert. | ||||
|      * @return Returns the internal value for value. | ||||
| @@ -288,14 +290,14 @@ public class TermuxSharedProperties { | ||||
|  | ||||
|     /** | ||||
|      * Returns the int for the value if its not null and is between | ||||
|      * {@code TermuxPropertyConstants#IVALUE_TERMINAL_CURSOR_BLINK_RATE_MIN} and | ||||
|      * {@code TermuxPropertyConstants#IVALUE_TERMINAL_CURSOR_BLINK_RATE_MAX}, | ||||
|      * otherwise returns {@code TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_CURSOR_BLINK_RATE}. | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_CURSOR_BLINK_RATE_MIN} and | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_CURSOR_BLINK_RATE_MAX}, | ||||
|      * otherwise returns {@link TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_CURSOR_BLINK_RATE}. | ||||
|      * | ||||
|      * @param value The {@link String} value to convert. | ||||
|      * @return Returns the internal value for value. | ||||
|      */ | ||||
|     public static float getTerminalCursorBlinkRateInternalPropertyValueFromValue(String value) { | ||||
|     public static int getTerminalCursorBlinkRateInternalPropertyValueFromValue(String value) { | ||||
|         return SharedProperties.getDefaultIfNotInRange(TermuxPropertyConstants.KEY_TERMINAL_CURSOR_BLINK_RATE, | ||||
|                     DataUtils.getIntFromString(value, TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_CURSOR_BLINK_RATE), | ||||
|                     TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_CURSOR_BLINK_RATE, | ||||
| @@ -305,15 +307,27 @@ public class TermuxSharedProperties { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the int for the value if its not null and is between | ||||
|      * {@code TermuxPropertyConstants#IVALUE_TERMINAL_TRANSCRIPT_ROWS_MIN} and | ||||
|      * {@code TermuxPropertyConstants#IVALUE_TERMINAL_TRANSCRIPT_ROWS_MAX}, | ||||
|      * otherwise returns {@code TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_TRANSCRIPT_ROWS}. | ||||
|      * Returns the internal value after mapping it based on | ||||
|      * {@link TermuxPropertyConstants#MAP_TERMINAL_CURSOR_STYLE} if the value is not {@code null} | ||||
|      * and is valid, otherwise returns {@link TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_CURSOR_STYLE}. | ||||
|      * | ||||
|      * @param value The {@link String} value to convert. | ||||
|      * @return Returns the internal value for value. | ||||
|      */ | ||||
|     public static float getTerminalTranscriptRowsInternalPropertyValueFromValue(String value) { | ||||
|     public static int getTerminalCursorStyleInternalPropertyValueFromValue(String value) { | ||||
|         return (int) SharedProperties.getDefaultIfNotInMap(TermuxPropertyConstants.KEY_TERMINAL_CURSOR_STYLE, TermuxPropertyConstants.MAP_TERMINAL_CURSOR_STYLE, SharedProperties.toLowerCase(value), TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_CURSOR_STYLE, true, LOG_TAG); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the int for the value if its not null and is between | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_TRANSCRIPT_ROWS_MIN} and | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_TRANSCRIPT_ROWS_MAX}, | ||||
|      * otherwise returns {@link TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_TRANSCRIPT_ROWS}. | ||||
|      * | ||||
|      * @param value The {@link String} value to convert. | ||||
|      * @return Returns the internal value for value. | ||||
|      */ | ||||
|     public static int getTerminalTranscriptRowsInternalPropertyValueFromValue(String value) { | ||||
|         return SharedProperties.getDefaultIfNotInRange(TermuxPropertyConstants.KEY_TERMINAL_TRANSCRIPT_ROWS, | ||||
|             DataUtils.getIntFromString(value, TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_TRANSCRIPT_ROWS), | ||||
|             TermuxPropertyConstants.DEFAULT_IVALUE_TERMINAL_TRANSCRIPT_ROWS, | ||||
| @@ -324,9 +338,9 @@ public class TermuxSharedProperties { | ||||
|  | ||||
|     /** | ||||
|      * Returns the int for the value if its not null and is between | ||||
|      * {@code TermuxPropertyConstants#IVALUE_TERMINAL_TOOLBAR_HEIGHT_SCALE_FACTOR_MIN} and | ||||
|      * {@code TermuxPropertyConstants#IVALUE_TERMINAL_TOOLBAR_HEIGHT_SCALE_FACTOR_MAX}, | ||||
|      * otherwise returns {@code TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_TOOLBAR_HEIGHT_SCALE_FACTOR}. | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_TOOLBAR_HEIGHT_SCALE_FACTOR_MIN} and | ||||
|      * {@link TermuxPropertyConstants#IVALUE_TERMINAL_TOOLBAR_HEIGHT_SCALE_FACTOR_MAX}, | ||||
|      * otherwise returns {@link TermuxPropertyConstants#DEFAULT_IVALUE_TERMINAL_TOOLBAR_HEIGHT_SCALE_FACTOR}. | ||||
|      * | ||||
|      * @param value The {@link String} value to convert. | ||||
|      * @return Returns the internal value for value. | ||||
| @@ -478,6 +492,10 @@ public class TermuxSharedProperties { | ||||
|         return (int) getInternalPropertyValue(TermuxPropertyConstants.KEY_TERMINAL_CURSOR_BLINK_RATE, true); | ||||
|     } | ||||
|  | ||||
|     public int getTerminalCursorStyle() { | ||||
|         return (int) getInternalPropertyValue(TermuxPropertyConstants.KEY_TERMINAL_CURSOR_STYLE, true); | ||||
|     } | ||||
|  | ||||
|     public int getTerminalTranscriptRows() { | ||||
|         return (int) getInternalPropertyValue(TermuxPropertyConstants.KEY_TERMINAL_TRANSCRIPT_ROWS, true); | ||||
|     } | ||||
|   | ||||
| @@ -39,6 +39,13 @@ public class TermuxTerminalSessionClientBase implements TerminalSessionClient { | ||||
|  | ||||
|  | ||||
|  | ||||
|     @Override | ||||
|     public Integer getTerminalCursorStyle() { | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|  | ||||
|  | ||||
|     @Override | ||||
|     public void logError(String tag, String message) { | ||||
|         Logger.logError(tag, message); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user