diff options
author | Björn Linse <bjorn.linse@gmail.com> | 2020-01-17 12:59:50 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-01-17 12:59:50 +0100 |
commit | fd89ad7bfb1534c42c99b36ca025ea42ccbee7e1 (patch) | |
tree | e9a50ea156867a93c3031e09c6d85573d8c397e7 /src/nvim/os/os_win_console.c | |
parent | 8fe0635e7338e32e8aedeb8f2e2c0f246876375c (diff) | |
parent | 1e4f29069146cbab0be0559d87e399aefa433a29 (diff) | |
download | rneovim-fd89ad7bfb1534c42c99b36ca025ea42ccbee7e1.tar.gz rneovim-fd89ad7bfb1534c42c99b36ca025ea42ccbee7e1.tar.bz2 rneovim-fd89ad7bfb1534c42c99b36ca025ea42ccbee7e1.zip |
Merge pull request #11390 from erw7/feature-conpty
win/Terminal: Change to use ConPTY, if available
Diffstat (limited to 'src/nvim/os/os_win_console.c')
-rw-r--r-- | src/nvim/os/os_win_console.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/src/nvim/os/os_win_console.c b/src/nvim/os/os_win_console.c new file mode 100644 index 0000000000..8a0aa2f5ae --- /dev/null +++ b/src/nvim/os/os_win_console.c @@ -0,0 +1,42 @@ +// This is an open source non-commercial project. Dear PVS-Studio, please check +// it. PVS-Studio Static Code Analyzer for C, C++ and C#: http://www.viva64.com + +#include "nvim/vim.h" +#include "nvim/os/os_win_console.h" + +int os_get_conin_fd(void) +{ + const HANDLE conin_handle = CreateFile("CONIN$", + GENERIC_READ | GENERIC_WRITE, + FILE_SHARE_READ | FILE_SHARE_WRITE, + (LPSECURITY_ATTRIBUTES)NULL, + OPEN_EXISTING, 0, (HANDLE)NULL); + assert(conin_handle != INVALID_HANDLE_VALUE); + int conin_fd = _open_osfhandle((intptr_t)conin_handle, _O_RDONLY); + assert(conin_fd != -1); + return conin_fd; +} + +void os_replace_stdin_to_conin(void) +{ + close(STDIN_FILENO); + const int conin_fd = os_get_conin_fd(); + assert(conin_fd == STDIN_FILENO); +} + +void os_replace_stdout_and_stderr_to_conout(void) +{ + const HANDLE conout_handle = + CreateFile("CONOUT$", + GENERIC_READ | GENERIC_WRITE, + FILE_SHARE_READ | FILE_SHARE_WRITE, + (LPSECURITY_ATTRIBUTES)NULL, + OPEN_EXISTING, 0, (HANDLE)NULL); + assert(conout_handle != INVALID_HANDLE_VALUE); + close(STDOUT_FILENO); + const int conout_fd = _open_osfhandle((intptr_t)conout_handle, 0); + assert(conout_fd == STDOUT_FILENO); + close(STDERR_FILENO); + const int conerr_fd = _open_osfhandle((intptr_t)conout_handle, 0); + assert(conerr_fd == STDERR_FILENO); +} |