SYNOPSIS
stty [
DESCRIPTION
stty sets or reports console mode settings on Windows systems. To set specific modes to off, add a - (dash) before each mode. Specifying a mode without a leading dash sets the mode to on.
Options
-a -
displays all current console modes. Each mode is displayed with a leading - (dash) if the mode is currently set to off; otherwise, only the mode name appears.
The
-a option does not display current settings for thehide orsane modes. A description of these special modes appears later in this reference page.
Control Modes
columns -
Defines the column width of your console window. This mode is system dependant, and returns an error if you specify a column width that is not supported by your operating system.
Optionally, you can specify a second argument (separated by a comma) that specifies the buffer size for the window. If you specify a column width with a comma but no buffer size, the current buffer size is used. If you specify a comma and a buffer size, but no column width, the current width is used. The following examples show how this can be used:
stty columns 80 sets window and buffer to 80 columns. stty columns 80, sets window to 80 columns without changing buffer. stty columns 80,1000 sets window to 80 columns and buffer to 1000. stty columns ,1000 sets buffer to 1000 column without changing window. stty columns , does nothing, silently.
If you set your window size too large to fit on your screen, it is truncated to a size that fits. If you set the buffer size smaller than the window size, the buffer size is reset to the window size.
cp -
Sets both the input and output code pages for the console window. This is equivalent to specifying both
icp andocp . The stty-a command displayscp when bothicp andocp are set to the same code page. It displays bothicp andocp when they differ.cp is only valid on 10/2016/2019/11/2022/2025. display -
Changes how the console window is displayed. There are four possible settings.
hide hides the console windowmax maximizes the console windowmin minimizes the console windowrestore restores the console windowOne use of this mode is in a KornShell script that performs graphical actions (for example a script with dlg commands), and you do not want the console visible while it is running. For example, you could start the shell script with
wstart -m sh.exe script.ksh
to minimize the window upon startup, and then have a stty
display hide command near the beginning of the script to hide the minimized window, effectively allowing the shell script to run without any visible indication that a console has been created. echo -
Corresponds to the Win32 ENABLE_ECHO_INPUT mode. If
echo is set, characters are echoed as they are read. This mode is only valid whenline mode is also on. Ifline mode is turned off,echo mode is automatically turned off by the stty command. erase -
Set the erase character. You can set this character to either the backspace or delete character, by specifying ^H or ^?, respectively.
If you do not specify a character to use as the erase character, the current erase character is displayed.
hide -
Does not correspond to any standard Win32 console mode, but allows hiding and restoring of the console window under Windows 95/98/Me. stty
hide hides the console window, and stty-hide brings it back.This mode is deprecated and should no longer be used. Use stty
display hide instead. icp -
Sets the input code page for the console window. The stty
-a command displayscp when bothicp andocp are set to the same code page. It displays bothicp andocp when they differ. pos -
Moves the top left corner of the console window to the screen co-ordinates specified. For example
stty pos 100,300
moves the top left corner to a position 100 pixels in from the left side of your screen and 300 pixels down from the top.
The screen co-ordinates can be negative. That is, you can move the console window past the left side or above the top of the screen. You can also move it as far down or to the right as you like, but be careful, as it is possible to move the console window beyond the visible screen.
iproc -
Corresponds to the Win32 ENABLE_PROCESSED_INPUT mode. This mode enables process input, meaning that any ^C is processed by the system as an interrupt and not passed to the program as input. Also, if
line mode is set,iproc mode tells the system to process backspace, carriage return, and linefeed characters. line -
Corresponds to the Win32 ENABLE_LINE_INPUT mode. If
line mode is set, programs reading from the console only receive input (one line at a time) once the ENTER key is pressed. If this mode is not set, programs reading the console receive the input as each key is pressed. minput -
Corresponds to the Win32 ENABLE_MOUSE_INPUT mode. Allows a console program to receive mouse related events.
ocp -
Sets the output code page for the console window. The stty
-a command displayscp when bothicp andocp are set to the same code page. It displays bothicp andocp when they differ. oproc -
Corresponds to the Win32 ENABLE_PROCESSED_OUTPUT mode. Allows ASCII control sequences and backspace, tab, bell, carriage return, and linefeed to be processed by the system. If this mode is not set, then these special ASCII characters simply appear on the screen as special characters, rather than the appropriate motion (or sound, in the case of the bell character).
owrap -
Corresponds to the Win32 ENABLE_WRAP_AT_EOL_OUTPUT mode. Allows output to wrap when it passes the rightmost column of the console. If this mode is not set, each line is truncated at the rightmost column of the console.
rows -
Define the row height of your console window. This mode is system dependant, and returns an error if you specify a row height that is not supported by your operating system.
Optionally, you can specify a second argument (separated by a comma) that specifies the buffer size for the window. If you specify a row height with a comma but no buffer size, the current buffer size is used. If you specify a comma and a buffer size, but no row height, the current height is used. The following examples show how this can be used:
stty rows 25 sets both window and buffer to 25 rows. stty rows 25, sets window to 25 rows without changing buffer. stty rows 25,1000 sets window to 25 rows and buffer to 1000 rows. stty rows ,1000 sets buffer to 1000 rows without changing window. stty rows , does nothing, silently.
If you set your window size too large to fit on your screen, it is truncated to a size that fits. If you set the buffer size smaller than the window size, the buffer size is reset to the window size.
sane -
Turns on all of the above input and output modes, which is the default (and typical) console mode. Using the stty
-sane command is not recommended, since it turns off all console modes. winput -
Corresponds to the Win32 ENABLE_WINDOW_INPUT mode. Allows a program to read events related to the resizing of a console window.
iinsert -
Corresponds to the Win32 ENABLE_INSERT_MODE mode. When enabled, text entered at the current location will be inserted, and text following that location will not be overwritten. Only supported on newer versions of Windows 10 or Server 2019.
iqedit -
Corresponds to the Win32 ENABLE_QUICK_EDIT_MODE mode. When enabled, the console will be in quick edit mode, allowing the user to select and edit text. Only supported on newer versions of Windows 10 or Server 2019.
ivterm -
Corresponds to the Win32 ENABLE_VIRTUAL_TERMINAL_INPUT mode. When enabled, user input will be converted into escape sequences. Only supported on newer versions of Windows 10 or Server 2019.
ovterm -
Corresponds to the Win32 ENABLE_VIRTUAL_TERMINAL_PROCESSING mode. When enabled, escape sequences will be processed when writing to the console. Only supported on newer versions of Windows 10 or Server 2019.
onewlin -
Corresponds to the Win32 DISABLE_NEWLINE_AUTO_RETURN mode. Only supported on newer versions of Windows 10 or Server 2019.
olvb -
Corresponds to the Win32 ENABLE_LVB_GRID_WORLDWIDE mode. Only supported on newer versions of Windows 10 or Server 2019.
Notes
Turning off console mode bits can be dangerous.
For example, if you do a stty
Certain mode bits are automatically forced to on by
cmd.exe and the
MKS KornShell (in
ENVIRONMENT VARIABLES
- TK_USE_CTRLD_AS_CONSOLE_EOF
-
When set, allows the use of CTRL-D as the EOF (end-of-file) character for the MKS KornShell (including sh, bash, ksh and resh) and MKS C Shell as well as for any utility that can accept input from the console.
DIAGNOSTICS
Possible exit status values are:
- 0
-
Successful completion.
- 1
-
All failures except command line option failure.
- 2
-
Failure due to an invalid command line option.
PORTABILITY
Windows 10. Windows Server 2016. Windows Server 2019. Windows 11. Windows Server 2022. Windows Server 2025.
The functionality of this command is a subset of the UNIX functionality.
AVAILABILITY
PTC MKS Toolkit for Power Users
PTC MKS Toolkit for System Administrators
PTC MKS Toolkit for Developers
PTC MKS Toolkit for Interoperability
PTC MKS Toolkit for Professional Developers
PTC MKS Toolkit for Professional Developers 64-Bit Edition
PTC MKS Toolkit for Enterprise Developers
PTC MKS Toolkit for Enterprise Developers 64-Bit Edition
PTC MKS Toolkit 10.5 Documentation Build 40.