@shitiandmw/node-pty 1.1.0-agent.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +69 -0
- package/README.md +170 -0
- package/binding.gyp +111 -0
- package/deps/.editorconfig +2 -0
- package/deps/winpty/.drone.yml +17 -0
- package/deps/winpty/.gitattributes +19 -0
- package/deps/winpty/LICENSE +21 -0
- package/deps/winpty/Makefile +166 -0
- package/deps/winpty/README.md +151 -0
- package/deps/winpty/RELEASES.md +280 -0
- package/deps/winpty/VERSION.txt +1 -0
- package/deps/winpty/configure +167 -0
- package/deps/winpty/misc/BufferResizeTests.cc +90 -0
- package/deps/winpty/misc/ChangeScreenBuffer.cc +53 -0
- package/deps/winpty/misc/ClearConsole.cc +72 -0
- package/deps/winpty/misc/ConinMode.cc +117 -0
- package/deps/winpty/misc/ConinMode.ps1 +116 -0
- package/deps/winpty/misc/ConoutMode.cc +113 -0
- package/deps/winpty/misc/DebugClient.py +42 -0
- package/deps/winpty/misc/DebugServer.py +63 -0
- package/deps/winpty/misc/DumpLines.py +5 -0
- package/deps/winpty/misc/EnableExtendedFlags.txt +46 -0
- package/deps/winpty/misc/Font-Report-June2016/CP437-Consolas.txt +528 -0
- package/deps/winpty/misc/Font-Report-June2016/CP437-Lucida.txt +633 -0
- package/deps/winpty/misc/Font-Report-June2016/CP932.txt +630 -0
- package/deps/winpty/misc/Font-Report-June2016/CP936.txt +630 -0
- package/deps/winpty/misc/Font-Report-June2016/CP949.txt +630 -0
- package/deps/winpty/misc/Font-Report-June2016/CP950.txt +630 -0
- package/deps/winpty/misc/Font-Report-June2016/MinimumWindowWidths.txt +16 -0
- package/deps/winpty/misc/Font-Report-June2016/Results.txt +4 -0
- package/deps/winpty/misc/Font-Report-June2016/Windows10SetFontBugginess.txt +144 -0
- package/deps/winpty/misc/FontSurvey.cc +100 -0
- package/deps/winpty/misc/FormatChar.h +21 -0
- package/deps/winpty/misc/FreezePerfTest.cc +62 -0
- package/deps/winpty/misc/GetCh.cc +20 -0
- package/deps/winpty/misc/GetConsolePos.cc +41 -0
- package/deps/winpty/misc/GetFont.cc +261 -0
- package/deps/winpty/misc/IdentifyConsoleWindow.ps1 +51 -0
- package/deps/winpty/misc/IsNewConsole.cc +87 -0
- package/deps/winpty/misc/MouseInputNotes.txt +90 -0
- package/deps/winpty/misc/MoveConsoleWindow.cc +34 -0
- package/deps/winpty/misc/Notes.txt +219 -0
- package/deps/winpty/misc/OSVersion.cc +27 -0
- package/deps/winpty/misc/ScreenBufferFreezeInactive.cc +101 -0
- package/deps/winpty/misc/ScreenBufferTest.cc +671 -0
- package/deps/winpty/misc/ScreenBufferTest2.cc +151 -0
- package/deps/winpty/misc/SelectAllTest.cc +45 -0
- package/deps/winpty/misc/SetBufferSize.cc +32 -0
- package/deps/winpty/misc/SetCursorPos.cc +10 -0
- package/deps/winpty/misc/SetFont.cc +145 -0
- package/deps/winpty/misc/SetWindowRect.cc +36 -0
- package/deps/winpty/misc/ShowArgv.cc +12 -0
- package/deps/winpty/misc/ShowConsoleInput.cc +40 -0
- package/deps/winpty/misc/Spew.py +5 -0
- package/deps/winpty/misc/TestUtil.cc +172 -0
- package/deps/winpty/misc/UnicodeDoubleWidthTest.cc +102 -0
- package/deps/winpty/misc/UnicodeWideTest1.cc +246 -0
- package/deps/winpty/misc/UnicodeWideTest2.cc +130 -0
- package/deps/winpty/misc/UnixEcho.cc +89 -0
- package/deps/winpty/misc/Utf16Echo.cc +46 -0
- package/deps/winpty/misc/VeryLargeRead.cc +122 -0
- package/deps/winpty/misc/VkEscapeTest.cc +56 -0
- package/deps/winpty/misc/Win10ResizeWhileFrozen.cc +52 -0
- package/deps/winpty/misc/Win10WrapTest1.cc +57 -0
- package/deps/winpty/misc/Win10WrapTest2.cc +30 -0
- package/deps/winpty/misc/Win32Echo1.cc +26 -0
- package/deps/winpty/misc/Win32Echo2.cc +19 -0
- package/deps/winpty/misc/Win32Test1.cc +46 -0
- package/deps/winpty/misc/Win32Test2.cc +70 -0
- package/deps/winpty/misc/Win32Test3.cc +78 -0
- package/deps/winpty/misc/Win32Write1.cc +44 -0
- package/deps/winpty/misc/WindowsBugCrashReader.cc +27 -0
- package/deps/winpty/misc/WriteConsole.cc +106 -0
- package/deps/winpty/misc/build32.sh +9 -0
- package/deps/winpty/misc/build64.sh +9 -0
- package/deps/winpty/misc/color-test.sh +212 -0
- package/deps/winpty/misc/font-notes.txt +300 -0
- package/deps/winpty/misc/winbug-15048.cc +201 -0
- package/deps/winpty/ship/build-pty4j-libpty.bat +36 -0
- package/deps/winpty/ship/common_ship.py +53 -0
- package/deps/winpty/ship/make_msvc_package.py +165 -0
- package/deps/winpty/ship/ship.py +108 -0
- package/deps/winpty/src/agent/Agent.cc +613 -0
- package/deps/winpty/src/agent/Agent.h +103 -0
- package/deps/winpty/src/agent/AgentCreateDesktop.cc +84 -0
- package/deps/winpty/src/agent/AgentCreateDesktop.h +28 -0
- package/deps/winpty/src/agent/ConsoleFont.cc +632 -0
- package/deps/winpty/src/agent/ConsoleFont.h +28 -0
- package/deps/winpty/src/agent/ConsoleInput.cc +852 -0
- package/deps/winpty/src/agent/ConsoleInput.h +109 -0
- package/deps/winpty/src/agent/ConsoleInputReencoding.cc +121 -0
- package/deps/winpty/src/agent/ConsoleInputReencoding.h +36 -0
- package/deps/winpty/src/agent/ConsoleLine.cc +152 -0
- package/deps/winpty/src/agent/ConsoleLine.h +41 -0
- package/deps/winpty/src/agent/Coord.h +87 -0
- package/deps/winpty/src/agent/DebugShowInput.cc +239 -0
- package/deps/winpty/src/agent/DebugShowInput.h +32 -0
- package/deps/winpty/src/agent/DefaultInputMap.cc +422 -0
- package/deps/winpty/src/agent/DefaultInputMap.h +28 -0
- package/deps/winpty/src/agent/DsrSender.h +30 -0
- package/deps/winpty/src/agent/EventLoop.cc +99 -0
- package/deps/winpty/src/agent/EventLoop.h +47 -0
- package/deps/winpty/src/agent/InputMap.cc +246 -0
- package/deps/winpty/src/agent/InputMap.h +114 -0
- package/deps/winpty/src/agent/LargeConsoleRead.cc +71 -0
- package/deps/winpty/src/agent/LargeConsoleRead.h +68 -0
- package/deps/winpty/src/agent/NamedPipe.cc +378 -0
- package/deps/winpty/src/agent/NamedPipe.h +125 -0
- package/deps/winpty/src/agent/Scraper.cc +699 -0
- package/deps/winpty/src/agent/Scraper.h +103 -0
- package/deps/winpty/src/agent/SimplePool.h +75 -0
- package/deps/winpty/src/agent/SmallRect.h +143 -0
- package/deps/winpty/src/agent/Terminal.cc +535 -0
- package/deps/winpty/src/agent/Terminal.h +69 -0
- package/deps/winpty/src/agent/UnicodeEncoding.h +157 -0
- package/deps/winpty/src/agent/UnicodeEncodingTest.cc +189 -0
- package/deps/winpty/src/agent/Win32Console.cc +107 -0
- package/deps/winpty/src/agent/Win32Console.h +67 -0
- package/deps/winpty/src/agent/Win32ConsoleBuffer.cc +193 -0
- package/deps/winpty/src/agent/Win32ConsoleBuffer.h +99 -0
- package/deps/winpty/src/agent/main.cc +114 -0
- package/deps/winpty/src/agent/subdir.mk +61 -0
- package/deps/winpty/src/configurations.gypi +60 -0
- package/deps/winpty/src/debugserver/DebugServer.cc +117 -0
- package/deps/winpty/src/debugserver/subdir.mk +41 -0
- package/deps/winpty/src/include/winpty.h +242 -0
- package/deps/winpty/src/include/winpty_constants.h +131 -0
- package/deps/winpty/src/libwinpty/AgentLocation.cc +75 -0
- package/deps/winpty/src/libwinpty/AgentLocation.h +28 -0
- package/deps/winpty/src/libwinpty/LibWinptyException.h +54 -0
- package/deps/winpty/src/libwinpty/WinptyInternal.h +72 -0
- package/deps/winpty/src/libwinpty/subdir.mk +46 -0
- package/deps/winpty/src/libwinpty/winpty.cc +970 -0
- package/deps/winpty/src/shared/AgentMsg.h +38 -0
- package/deps/winpty/src/shared/BackgroundDesktop.cc +122 -0
- package/deps/winpty/src/shared/BackgroundDesktop.h +73 -0
- package/deps/winpty/src/shared/Buffer.cc +103 -0
- package/deps/winpty/src/shared/Buffer.h +102 -0
- package/deps/winpty/src/shared/DebugClient.cc +187 -0
- package/deps/winpty/src/shared/DebugClient.h +38 -0
- package/deps/winpty/src/shared/GenRandom.cc +138 -0
- package/deps/winpty/src/shared/GenRandom.h +55 -0
- package/deps/winpty/src/shared/GetCommitHash.bat +13 -0
- package/deps/winpty/src/shared/Mutex.h +54 -0
- package/deps/winpty/src/shared/OsModule.h +63 -0
- package/deps/winpty/src/shared/OwnedHandle.cc +36 -0
- package/deps/winpty/src/shared/OwnedHandle.h +45 -0
- package/deps/winpty/src/shared/PrecompiledHeader.h +43 -0
- package/deps/winpty/src/shared/StringBuilder.h +227 -0
- package/deps/winpty/src/shared/StringBuilderTest.cc +114 -0
- package/deps/winpty/src/shared/StringUtil.cc +55 -0
- package/deps/winpty/src/shared/StringUtil.h +80 -0
- package/deps/winpty/src/shared/TimeMeasurement.h +63 -0
- package/deps/winpty/src/shared/UnixCtrlChars.h +45 -0
- package/deps/winpty/src/shared/UpdateGenVersion.bat +20 -0
- package/deps/winpty/src/shared/WindowsSecurity.cc +460 -0
- package/deps/winpty/src/shared/WindowsSecurity.h +104 -0
- package/deps/winpty/src/shared/WindowsVersion.cc +252 -0
- package/deps/winpty/src/shared/WindowsVersion.h +29 -0
- package/deps/winpty/src/shared/WinptyAssert.cc +55 -0
- package/deps/winpty/src/shared/WinptyAssert.h +64 -0
- package/deps/winpty/src/shared/WinptyException.cc +57 -0
- package/deps/winpty/src/shared/WinptyException.h +43 -0
- package/deps/winpty/src/shared/WinptyVersion.cc +42 -0
- package/deps/winpty/src/shared/WinptyVersion.h +27 -0
- package/deps/winpty/src/shared/winpty_snprintf.h +99 -0
- package/deps/winpty/src/subdir.mk +5 -0
- package/deps/winpty/src/tests/subdir.mk +28 -0
- package/deps/winpty/src/tests/trivial_test.cc +158 -0
- package/deps/winpty/src/unix-adapter/InputHandler.cc +114 -0
- package/deps/winpty/src/unix-adapter/InputHandler.h +56 -0
- package/deps/winpty/src/unix-adapter/OutputHandler.cc +80 -0
- package/deps/winpty/src/unix-adapter/OutputHandler.h +53 -0
- package/deps/winpty/src/unix-adapter/Util.cc +86 -0
- package/deps/winpty/src/unix-adapter/Util.h +31 -0
- package/deps/winpty/src/unix-adapter/WakeupFd.cc +70 -0
- package/deps/winpty/src/unix-adapter/WakeupFd.h +42 -0
- package/deps/winpty/src/unix-adapter/main.cc +729 -0
- package/deps/winpty/src/unix-adapter/subdir.mk +41 -0
- package/deps/winpty/src/winpty.gyp +234 -0
- package/deps/winpty/vcbuild.bat +83 -0
- package/lib/conpty_console_list_agent.js +16 -0
- package/lib/conpty_console_list_agent.js.map +1 -0
- package/lib/eventEmitter2.js +47 -0
- package/lib/eventEmitter2.js.map +1 -0
- package/lib/eventEmitter2.test.js +30 -0
- package/lib/eventEmitter2.test.js.map +1 -0
- package/lib/index.js +52 -0
- package/lib/index.js.map +1 -0
- package/lib/interfaces.js +7 -0
- package/lib/interfaces.js.map +1 -0
- package/lib/shared/conout.js +11 -0
- package/lib/shared/conout.js.map +1 -0
- package/lib/terminal.js +190 -0
- package/lib/terminal.js.map +1 -0
- package/lib/terminal.test.js +139 -0
- package/lib/terminal.test.js.map +1 -0
- package/lib/testUtils.test.js +28 -0
- package/lib/testUtils.test.js.map +1 -0
- package/lib/types.js +7 -0
- package/lib/types.js.map +1 -0
- package/lib/unixTerminal.js +346 -0
- package/lib/unixTerminal.js.map +1 -0
- package/lib/unixTerminal.test.js +351 -0
- package/lib/unixTerminal.test.js.map +1 -0
- package/lib/utils.js +39 -0
- package/lib/utils.js.map +1 -0
- package/lib/windowsConoutConnection.js +125 -0
- package/lib/windowsConoutConnection.js.map +1 -0
- package/lib/windowsPtyAgent.js +320 -0
- package/lib/windowsPtyAgent.js.map +1 -0
- package/lib/windowsPtyAgent.test.js +90 -0
- package/lib/windowsPtyAgent.test.js.map +1 -0
- package/lib/windowsTerminal.js +199 -0
- package/lib/windowsTerminal.js.map +1 -0
- package/lib/windowsTerminal.test.js +219 -0
- package/lib/windowsTerminal.test.js.map +1 -0
- package/lib/worker/conoutSocketWorker.js +22 -0
- package/lib/worker/conoutSocketWorker.js.map +1 -0
- package/package.json +68 -0
- package/prebuilds/darwin-arm64/pty.node +0 -0
- package/prebuilds/darwin-arm64/spawn-helper +0 -0
- package/prebuilds/darwin-x64/pty.node +0 -0
- package/prebuilds/darwin-x64/spawn-helper +0 -0
- package/prebuilds/win32-arm64/conpty/OpenConsole.exe +0 -0
- package/prebuilds/win32-arm64/conpty/conpty.dll +0 -0
- package/prebuilds/win32-arm64/conpty.node +0 -0
- package/prebuilds/win32-arm64/conpty.pdb +0 -0
- package/prebuilds/win32-arm64/conpty_console_list.node +0 -0
- package/prebuilds/win32-arm64/conpty_console_list.pdb +0 -0
- package/prebuilds/win32-arm64/pty.node +0 -0
- package/prebuilds/win32-arm64/pty.pdb +0 -0
- package/prebuilds/win32-arm64/winpty-agent.exe +0 -0
- package/prebuilds/win32-arm64/winpty-agent.pdb +0 -0
- package/prebuilds/win32-arm64/winpty.dll +0 -0
- package/prebuilds/win32-arm64/winpty.pdb +0 -0
- package/prebuilds/win32-x64/conpty/OpenConsole.exe +0 -0
- package/prebuilds/win32-x64/conpty/conpty.dll +0 -0
- package/prebuilds/win32-x64/conpty.node +0 -0
- package/prebuilds/win32-x64/conpty.pdb +0 -0
- package/prebuilds/win32-x64/conpty_console_list.node +0 -0
- package/prebuilds/win32-x64/conpty_console_list.pdb +0 -0
- package/prebuilds/win32-x64/pty.node +0 -0
- package/prebuilds/win32-x64/pty.pdb +0 -0
- package/prebuilds/win32-x64/winpty-agent.exe +0 -0
- package/prebuilds/win32-x64/winpty-agent.pdb +0 -0
- package/prebuilds/win32-x64/winpty.dll +0 -0
- package/prebuilds/win32-x64/winpty.pdb +0 -0
- package/scripts/gen-compile-commands.js +8 -0
- package/scripts/increment-version.js +54 -0
- package/scripts/post-install.js +99 -0
- package/scripts/prebuild.js +39 -0
- package/scripts/sync-prebuild.js +31 -0
- package/scripts/verify-darwin-fd-leak.js +63 -0
- package/src/conpty_console_list_agent.ts +15 -0
- package/src/eventEmitter2.test.ts +30 -0
- package/src/eventEmitter2.ts +48 -0
- package/src/index.ts +52 -0
- package/src/interfaces.ts +130 -0
- package/src/native.d.ts +54 -0
- package/src/shared/conout.ts +15 -0
- package/src/terminal.test.ts +119 -0
- package/src/terminal.ts +211 -0
- package/src/testUtils.test.ts +23 -0
- package/src/tsconfig.json +22 -0
- package/src/types.ts +15 -0
- package/src/unix/pty.cc +808 -0
- package/src/unix/spawn-helper.cc +23 -0
- package/src/unixTerminal.test.ts +367 -0
- package/src/unixTerminal.ts +388 -0
- package/src/utils.ts +29 -0
- package/src/win/conpty.cc +583 -0
- package/src/win/conpty.h +41 -0
- package/src/win/conpty_console_list.cc +44 -0
- package/src/win/path_util.cc +95 -0
- package/src/win/path_util.h +26 -0
- package/src/win/winpty.cc +333 -0
- package/src/windowsConoutConnection.ts +82 -0
- package/src/windowsPtyAgent.test.ts +94 -0
- package/src/windowsPtyAgent.ts +321 -0
- package/src/windowsTerminal.test.ts +229 -0
- package/src/windowsTerminal.ts +203 -0
- package/src/worker/conoutSocketWorker.ts +22 -0
- package/third_party/conpty/1.23.251008001/win10-arm64/OpenConsole.exe +0 -0
- package/third_party/conpty/1.23.251008001/win10-arm64/conpty.dll +0 -0
- package/third_party/conpty/1.23.251008001/win10-x64/OpenConsole.exe +0 -0
- package/third_party/conpty/1.23.251008001/win10-x64/conpty.dll +0 -0
- package/typings/node-pty.d.ts +211 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
// A test program for CreateConsoleScreenBuffer / SetConsoleActiveScreenBuffer
|
|
2
|
+
//
|
|
3
|
+
|
|
4
|
+
#include <windows.h>
|
|
5
|
+
#include <stdio.h>
|
|
6
|
+
#include <conio.h>
|
|
7
|
+
#include <io.h>
|
|
8
|
+
#include <cassert>
|
|
9
|
+
|
|
10
|
+
#include "TestUtil.cc"
|
|
11
|
+
|
|
12
|
+
int main()
|
|
13
|
+
{
|
|
14
|
+
HANDLE origBuffer = GetStdHandle(STD_OUTPUT_HANDLE);
|
|
15
|
+
HANDLE childBuffer = CreateConsoleScreenBuffer(
|
|
16
|
+
GENERIC_READ | GENERIC_WRITE,
|
|
17
|
+
FILE_SHARE_READ | FILE_SHARE_WRITE,
|
|
18
|
+
NULL, CONSOLE_TEXTMODE_BUFFER, NULL);
|
|
19
|
+
|
|
20
|
+
SetConsoleActiveScreenBuffer(childBuffer);
|
|
21
|
+
|
|
22
|
+
while (true) {
|
|
23
|
+
char buf[1024];
|
|
24
|
+
CONSOLE_SCREEN_BUFFER_INFO info;
|
|
25
|
+
|
|
26
|
+
assert(GetConsoleScreenBufferInfo(origBuffer, &info));
|
|
27
|
+
trace("child.size=(%d,%d)", (int)info.dwSize.X, (int)info.dwSize.Y);
|
|
28
|
+
trace("child.cursor=(%d,%d)", (int)info.dwCursorPosition.X, (int)info.dwCursorPosition.Y);
|
|
29
|
+
trace("child.window=(%d,%d,%d,%d)",
|
|
30
|
+
(int)info.srWindow.Left, (int)info.srWindow.Top,
|
|
31
|
+
(int)info.srWindow.Right, (int)info.srWindow.Bottom);
|
|
32
|
+
trace("child.maxSize=(%d,%d)", (int)info.dwMaximumWindowSize.X, (int)info.dwMaximumWindowSize.Y);
|
|
33
|
+
|
|
34
|
+
int ch = getch();
|
|
35
|
+
sprintf(buf, "%02x\n", ch);
|
|
36
|
+
DWORD actual = 0;
|
|
37
|
+
WriteFile(childBuffer, buf, strlen(buf), &actual, NULL);
|
|
38
|
+
if (ch == 0x1b/*ESC*/ || ch == 0x03/*CTRL-C*/)
|
|
39
|
+
break;
|
|
40
|
+
|
|
41
|
+
if (ch == 'b') {
|
|
42
|
+
setBufferSize(origBuffer, 40, 25);
|
|
43
|
+
} else if (ch == 'w') {
|
|
44
|
+
setWindowPos(origBuffer, 1, 1, 38, 23);
|
|
45
|
+
} else if (ch == 'c') {
|
|
46
|
+
setCursorPos(origBuffer, 10, 10);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
SetConsoleActiveScreenBuffer(origBuffer);
|
|
51
|
+
|
|
52
|
+
return 0;
|
|
53
|
+
}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Demonstrates that console clearing sets each cell's character to SP, not
|
|
3
|
+
* NUL, and it sets the attribute of each cell to the current text attribute.
|
|
4
|
+
*
|
|
5
|
+
* This confirms the MSDN instruction in the "Clearing the Screen" article.
|
|
6
|
+
* https://msdn.microsoft.com/en-us/library/windows/desktop/ms682022(v=vs.85).aspx
|
|
7
|
+
* It advises using GetConsoleScreenBufferInfo to get the current text
|
|
8
|
+
* attribute, then FillConsoleOutputCharacter and FillConsoleOutputAttribute to
|
|
9
|
+
* write to the console buffer.
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
#include <windows.h>
|
|
13
|
+
|
|
14
|
+
#include <cassert>
|
|
15
|
+
#include <cstdio>
|
|
16
|
+
#include <cstdlib>
|
|
17
|
+
|
|
18
|
+
#include "TestUtil.cc"
|
|
19
|
+
|
|
20
|
+
int main(int argc, char *argv[]) {
|
|
21
|
+
if (argc == 1) {
|
|
22
|
+
startChildProcess(L"CHILD");
|
|
23
|
+
return 0;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const HANDLE conout = GetStdHandle(STD_OUTPUT_HANDLE);
|
|
27
|
+
|
|
28
|
+
SetConsoleTextAttribute(conout, 0x24);
|
|
29
|
+
system("cls");
|
|
30
|
+
|
|
31
|
+
setWindowPos(0, 0, 1, 1);
|
|
32
|
+
setBufferSize(80, 25);
|
|
33
|
+
setWindowPos(0, 0, 80, 25);
|
|
34
|
+
|
|
35
|
+
CHAR_INFO buf;
|
|
36
|
+
COORD bufSize = { 1, 1 };
|
|
37
|
+
COORD bufCoord = { 0, 0 };
|
|
38
|
+
SMALL_RECT rect = { 5, 5, 5, 5 };
|
|
39
|
+
BOOL ret;
|
|
40
|
+
DWORD actual;
|
|
41
|
+
COORD writeCoord = { 5, 5 };
|
|
42
|
+
|
|
43
|
+
// After cls, each cell's character is a space, and its attributes are the
|
|
44
|
+
// default text attributes.
|
|
45
|
+
ret = ReadConsoleOutputW(conout, &buf, bufSize, bufCoord, &rect);
|
|
46
|
+
assert(ret && buf.Char.UnicodeChar == L' ' && buf.Attributes == 0x24);
|
|
47
|
+
|
|
48
|
+
// Nevertheless, it is possible to change a cell to NUL.
|
|
49
|
+
ret = FillConsoleOutputCharacterW(conout, L'\0', 1, writeCoord, &actual);
|
|
50
|
+
assert(ret && actual == 1);
|
|
51
|
+
ret = ReadConsoleOutputW(conout, &buf, bufSize, bufCoord, &rect);
|
|
52
|
+
assert(ret && buf.Char.UnicodeChar == L'\0' && buf.Attributes == 0x24);
|
|
53
|
+
|
|
54
|
+
// As well as a 0 attribute. (As one would expect, the cell is
|
|
55
|
+
// black-on-black.)
|
|
56
|
+
ret = FillConsoleOutputAttribute(conout, 0, 1, writeCoord, &actual);
|
|
57
|
+
assert(ret && actual == 1);
|
|
58
|
+
ret = ReadConsoleOutputW(conout, &buf, bufSize, bufCoord, &rect);
|
|
59
|
+
assert(ret && buf.Char.UnicodeChar == L'\0' && buf.Attributes == 0);
|
|
60
|
+
ret = FillConsoleOutputCharacterW(conout, L'X', 1, writeCoord, &actual);
|
|
61
|
+
assert(ret && actual == 1);
|
|
62
|
+
ret = ReadConsoleOutputW(conout, &buf, bufSize, bufCoord, &rect);
|
|
63
|
+
assert(ret && buf.Char.UnicodeChar == L'X' && buf.Attributes == 0);
|
|
64
|
+
|
|
65
|
+
// The 'X' is invisible.
|
|
66
|
+
countDown(3);
|
|
67
|
+
|
|
68
|
+
ret = FillConsoleOutputAttribute(conout, 0x42, 1, writeCoord, &actual);
|
|
69
|
+
assert(ret && actual == 1);
|
|
70
|
+
|
|
71
|
+
countDown(5);
|
|
72
|
+
}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
#include <windows.h>
|
|
2
|
+
|
|
3
|
+
#include <errno.h>
|
|
4
|
+
#include <stdio.h>
|
|
5
|
+
#include <stdlib.h>
|
|
6
|
+
|
|
7
|
+
#include <string>
|
|
8
|
+
#include <vector>
|
|
9
|
+
|
|
10
|
+
static HANDLE getConin() {
|
|
11
|
+
HANDLE conin = GetStdHandle(STD_INPUT_HANDLE);
|
|
12
|
+
if (conin == INVALID_HANDLE_VALUE) {
|
|
13
|
+
fprintf(stderr, "error: cannot get stdin\n");
|
|
14
|
+
exit(1);
|
|
15
|
+
}
|
|
16
|
+
return conin;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
static DWORD getConsoleMode() {
|
|
20
|
+
DWORD mode = 0;
|
|
21
|
+
if (!GetConsoleMode(getConin(), &mode)) {
|
|
22
|
+
fprintf(stderr, "error: GetConsoleMode failed (is stdin a console?)\n");
|
|
23
|
+
exit(1);
|
|
24
|
+
}
|
|
25
|
+
return mode;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
static void setConsoleMode(DWORD mode) {
|
|
29
|
+
if (!SetConsoleMode(getConin(), mode)) {
|
|
30
|
+
fprintf(stderr, "error: SetConsoleMode failed (is stdin a console?)\n");
|
|
31
|
+
exit(1);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
static long parseInt(const std::string &s) {
|
|
36
|
+
errno = 0;
|
|
37
|
+
char *endptr = nullptr;
|
|
38
|
+
long result = strtol(s.c_str(), &endptr, 0);
|
|
39
|
+
if (errno != 0 || !endptr || *endptr != '\0') {
|
|
40
|
+
fprintf(stderr, "error: could not parse integral argument '%s'\n", s.c_str());
|
|
41
|
+
exit(1);
|
|
42
|
+
}
|
|
43
|
+
return result;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
static void usage() {
|
|
47
|
+
printf("Usage: ConinMode [verb] [options]\n");
|
|
48
|
+
printf("Verbs:\n");
|
|
49
|
+
printf(" [info] Dumps info about mode flags.\n");
|
|
50
|
+
printf(" get Prints the mode DWORD.\n");
|
|
51
|
+
printf(" set VALUE Sets the mode to VALUE, which can be decimal, hex, or octal.\n");
|
|
52
|
+
printf(" set VALUE MASK\n");
|
|
53
|
+
printf(" Same as `set VALUE`, but only alters the bits in MASK.\n");
|
|
54
|
+
exit(1);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
struct {
|
|
58
|
+
const char *name;
|
|
59
|
+
DWORD value;
|
|
60
|
+
} kInputFlags[] = {
|
|
61
|
+
"ENABLE_PROCESSED_INPUT", ENABLE_PROCESSED_INPUT, // 0x0001
|
|
62
|
+
"ENABLE_LINE_INPUT", ENABLE_LINE_INPUT, // 0x0002
|
|
63
|
+
"ENABLE_ECHO_INPUT", ENABLE_ECHO_INPUT, // 0x0004
|
|
64
|
+
"ENABLE_WINDOW_INPUT", ENABLE_WINDOW_INPUT, // 0x0008
|
|
65
|
+
"ENABLE_MOUSE_INPUT", ENABLE_MOUSE_INPUT, // 0x0010
|
|
66
|
+
"ENABLE_INSERT_MODE", ENABLE_INSERT_MODE, // 0x0020
|
|
67
|
+
"ENABLE_QUICK_EDIT_MODE", ENABLE_QUICK_EDIT_MODE, // 0x0040
|
|
68
|
+
"ENABLE_EXTENDED_FLAGS", ENABLE_EXTENDED_FLAGS, // 0x0080
|
|
69
|
+
"ENABLE_VIRTUAL_TERMINAL_INPUT", 0x0200/*ENABLE_VIRTUAL_TERMINAL_INPUT*/, // 0x0200
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
int main(int argc, char *argv[]) {
|
|
73
|
+
std::vector<std::string> args;
|
|
74
|
+
for (size_t i = 1; i < argc; ++i) {
|
|
75
|
+
args.push_back(argv[i]);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
if (args.empty() || args.size() == 1 && args[0] == "info") {
|
|
79
|
+
DWORD mode = getConsoleMode();
|
|
80
|
+
printf("mode: 0x%lx\n", mode);
|
|
81
|
+
for (const auto &flag : kInputFlags) {
|
|
82
|
+
printf("%-29s 0x%04lx %s\n", flag.name, flag.value, flag.value & mode ? "ON" : "off");
|
|
83
|
+
mode &= ~flag.value;
|
|
84
|
+
}
|
|
85
|
+
for (int i = 0; i < 32; ++i) {
|
|
86
|
+
if (mode & (1u << i)) {
|
|
87
|
+
printf("Unrecognized flag: %04x\n", (1u << i));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return 0;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
const auto verb = args[0];
|
|
94
|
+
|
|
95
|
+
if (verb == "set") {
|
|
96
|
+
if (args.size() == 2) {
|
|
97
|
+
const DWORD newMode = parseInt(args[1]);
|
|
98
|
+
setConsoleMode(newMode);
|
|
99
|
+
} else if (args.size() == 3) {
|
|
100
|
+
const DWORD mode = parseInt(args[1]);
|
|
101
|
+
const DWORD mask = parseInt(args[2]);
|
|
102
|
+
const int newMode = (getConsoleMode() & ~mask) | (mode & mask);
|
|
103
|
+
setConsoleMode(newMode);
|
|
104
|
+
} else {
|
|
105
|
+
usage();
|
|
106
|
+
}
|
|
107
|
+
} else if (verb == "get") {
|
|
108
|
+
if (args.size() != 1) {
|
|
109
|
+
usage();
|
|
110
|
+
}
|
|
111
|
+
printf("0x%lx\n", getConsoleMode());
|
|
112
|
+
} else {
|
|
113
|
+
usage();
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
return 0;
|
|
117
|
+
}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
#
|
|
2
|
+
# PowerShell script for controlling the console QuickEdit and InsertMode flags.
|
|
3
|
+
#
|
|
4
|
+
# Turn QuickEdit off to interact with mouse-driven console programs.
|
|
5
|
+
#
|
|
6
|
+
# Usage:
|
|
7
|
+
#
|
|
8
|
+
# powershell .\ConinMode.ps1 [Options]
|
|
9
|
+
#
|
|
10
|
+
# Options:
|
|
11
|
+
# -QuickEdit [on/off]
|
|
12
|
+
# -InsertMode [on/off]
|
|
13
|
+
# -Mode [integer]
|
|
14
|
+
#
|
|
15
|
+
|
|
16
|
+
param (
|
|
17
|
+
[ValidateSet("on", "off")][string] $QuickEdit,
|
|
18
|
+
[ValidateSet("on", "off")][string] $InsertMode,
|
|
19
|
+
[int] $Mode
|
|
20
|
+
)
|
|
21
|
+
|
|
22
|
+
$signature = @'
|
|
23
|
+
[DllImport("kernel32.dll", SetLastError = true)]
|
|
24
|
+
public static extern IntPtr GetStdHandle(int nStdHandle);
|
|
25
|
+
|
|
26
|
+
[DllImport("kernel32.dll", SetLastError = true)]
|
|
27
|
+
public static extern uint GetConsoleMode(
|
|
28
|
+
IntPtr hConsoleHandle,
|
|
29
|
+
out uint lpMode);
|
|
30
|
+
|
|
31
|
+
[DllImport("kernel32.dll", SetLastError = true)]
|
|
32
|
+
public static extern uint SetConsoleMode(
|
|
33
|
+
IntPtr hConsoleHandle,
|
|
34
|
+
uint dwMode);
|
|
35
|
+
|
|
36
|
+
public const int STD_INPUT_HANDLE = -10;
|
|
37
|
+
public const int ENABLE_INSERT_MODE = 0x0020;
|
|
38
|
+
public const int ENABLE_QUICK_EDIT_MODE = 0x0040;
|
|
39
|
+
public const int ENABLE_EXTENDED_FLAGS = 0x0080;
|
|
40
|
+
'@
|
|
41
|
+
|
|
42
|
+
$WinAPI = Add-Type -MemberDefinition $signature `
|
|
43
|
+
-Name WinAPI -Namespace ConinModeScript `
|
|
44
|
+
-PassThru
|
|
45
|
+
|
|
46
|
+
function GetConIn {
|
|
47
|
+
$ret = $WinAPI::GetStdHandle($WinAPI::STD_INPUT_HANDLE)
|
|
48
|
+
if ($ret -eq -1) {
|
|
49
|
+
throw "error: cannot get stdin"
|
|
50
|
+
}
|
|
51
|
+
return $ret
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function GetConsoleMode {
|
|
55
|
+
$conin = GetConIn
|
|
56
|
+
$mode = 0
|
|
57
|
+
$ret = $WinAPI::GetConsoleMode($conin, [ref]$mode)
|
|
58
|
+
if ($ret -eq 0) {
|
|
59
|
+
throw "GetConsoleMode failed (is stdin a console?)"
|
|
60
|
+
}
|
|
61
|
+
return $mode
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
function SetConsoleMode($mode) {
|
|
65
|
+
$conin = GetConIn
|
|
66
|
+
$ret = $WinAPI::SetConsoleMode($conin, $mode)
|
|
67
|
+
if ($ret -eq 0) {
|
|
68
|
+
throw "SetConsoleMode failed (is stdin a console?)"
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
$oldMode = GetConsoleMode
|
|
73
|
+
$newMode = $oldMode
|
|
74
|
+
$doingSomething = $false
|
|
75
|
+
|
|
76
|
+
if ($PSBoundParameters.ContainsKey("Mode")) {
|
|
77
|
+
$newMode = $Mode
|
|
78
|
+
$doingSomething = $true
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
if ($QuickEdit + $InsertMode -ne "") {
|
|
82
|
+
if (!($newMode -band $WinAPI::ENABLE_EXTENDED_FLAGS)) {
|
|
83
|
+
# We can't enable an extended flag without overwriting the existing
|
|
84
|
+
# QuickEdit/InsertMode flags. AFAICT, there is no way to query their
|
|
85
|
+
# existing values, so at least we can choose sensible defaults.
|
|
86
|
+
$newMode = $newMode -bor $WinAPI::ENABLE_EXTENDED_FLAGS
|
|
87
|
+
$newMode = $newMode -bor $WinAPI::ENABLE_QUICK_EDIT_MODE
|
|
88
|
+
$newMode = $newMode -bor $WinAPI::ENABLE_INSERT_MODE
|
|
89
|
+
$doingSomething = $true
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
if ($QuickEdit -eq "on") {
|
|
94
|
+
$newMode = $newMode -bor $WinAPI::ENABLE_QUICK_EDIT_MODE
|
|
95
|
+
$doingSomething = $true
|
|
96
|
+
} elseif ($QuickEdit -eq "off") {
|
|
97
|
+
$newMode = $newMode -band (-bnot $WinAPI::ENABLE_QUICK_EDIT_MODE)
|
|
98
|
+
$doingSomething = $true
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
if ($InsertMode -eq "on") {
|
|
102
|
+
$newMode = $newMode -bor $WinAPI::ENABLE_INSERT_MODE
|
|
103
|
+
$doingSomething = $true
|
|
104
|
+
} elseif ($InsertMode -eq "off") {
|
|
105
|
+
$newMode = $newMode -band (-bnot $WinAPI::ENABLE_INSERT_MODE)
|
|
106
|
+
$doingSomething = $true
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
if ($doingSomething) {
|
|
110
|
+
echo "old mode: $oldMode"
|
|
111
|
+
SetConsoleMode $newMode
|
|
112
|
+
$newMode = GetConsoleMode
|
|
113
|
+
echo "new mode: $newMode"
|
|
114
|
+
} else {
|
|
115
|
+
echo "mode: $oldMode"
|
|
116
|
+
}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
#include <windows.h>
|
|
2
|
+
|
|
3
|
+
#include <errno.h>
|
|
4
|
+
#include <stdio.h>
|
|
5
|
+
#include <stdlib.h>
|
|
6
|
+
|
|
7
|
+
#include <string>
|
|
8
|
+
#include <vector>
|
|
9
|
+
|
|
10
|
+
static HANDLE getConout() {
|
|
11
|
+
HANDLE conout = GetStdHandle(STD_OUTPUT_HANDLE);
|
|
12
|
+
if (conout == INVALID_HANDLE_VALUE) {
|
|
13
|
+
fprintf(stderr, "error: cannot get stdout\n");
|
|
14
|
+
exit(1);
|
|
15
|
+
}
|
|
16
|
+
return conout;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
static DWORD getConsoleMode() {
|
|
20
|
+
DWORD mode = 0;
|
|
21
|
+
if (!GetConsoleMode(getConout(), &mode)) {
|
|
22
|
+
fprintf(stderr, "error: GetConsoleMode failed (is stdout a console?)\n");
|
|
23
|
+
exit(1);
|
|
24
|
+
}
|
|
25
|
+
return mode;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
static void setConsoleMode(DWORD mode) {
|
|
29
|
+
if (!SetConsoleMode(getConout(), mode)) {
|
|
30
|
+
fprintf(stderr, "error: SetConsoleMode failed (is stdout a console?)\n");
|
|
31
|
+
exit(1);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
static long parseInt(const std::string &s) {
|
|
36
|
+
errno = 0;
|
|
37
|
+
char *endptr = nullptr;
|
|
38
|
+
long result = strtol(s.c_str(), &endptr, 0);
|
|
39
|
+
if (errno != 0 || !endptr || *endptr != '\0') {
|
|
40
|
+
fprintf(stderr, "error: could not parse integral argument '%s'\n", s.c_str());
|
|
41
|
+
exit(1);
|
|
42
|
+
}
|
|
43
|
+
return result;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
static void usage() {
|
|
47
|
+
printf("Usage: ConoutMode [verb] [options]\n");
|
|
48
|
+
printf("Verbs:\n");
|
|
49
|
+
printf(" [info] Dumps info about mode flags.\n");
|
|
50
|
+
printf(" get Prints the mode DWORD.\n");
|
|
51
|
+
printf(" set VALUE Sets the mode to VALUE, which can be decimal, hex, or octal.\n");
|
|
52
|
+
printf(" set VALUE MASK\n");
|
|
53
|
+
printf(" Same as `set VALUE`, but only alters the bits in MASK.\n");
|
|
54
|
+
exit(1);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
struct {
|
|
58
|
+
const char *name;
|
|
59
|
+
DWORD value;
|
|
60
|
+
} kOutputFlags[] = {
|
|
61
|
+
"ENABLE_PROCESSED_OUTPUT", ENABLE_PROCESSED_OUTPUT, // 0x0001
|
|
62
|
+
"ENABLE_WRAP_AT_EOL_OUTPUT", ENABLE_WRAP_AT_EOL_OUTPUT, // 0x0002
|
|
63
|
+
"ENABLE_VIRTUAL_TERMINAL_PROCESSING", 0x0004/*ENABLE_VIRTUAL_TERMINAL_PROCESSING*/, // 0x0004
|
|
64
|
+
"DISABLE_NEWLINE_AUTO_RETURN", 0x0008/*DISABLE_NEWLINE_AUTO_RETURN*/, // 0x0008
|
|
65
|
+
"ENABLE_LVB_GRID_WORLDWIDE", 0x0010/*ENABLE_LVB_GRID_WORLDWIDE*/, //0x0010
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
int main(int argc, char *argv[]) {
|
|
69
|
+
std::vector<std::string> args;
|
|
70
|
+
for (size_t i = 1; i < argc; ++i) {
|
|
71
|
+
args.push_back(argv[i]);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
if (args.empty() || args.size() == 1 && args[0] == "info") {
|
|
75
|
+
DWORD mode = getConsoleMode();
|
|
76
|
+
printf("mode: 0x%lx\n", mode);
|
|
77
|
+
for (const auto &flag : kOutputFlags) {
|
|
78
|
+
printf("%-34s 0x%04lx %s\n", flag.name, flag.value, flag.value & mode ? "ON" : "off");
|
|
79
|
+
mode &= ~flag.value;
|
|
80
|
+
}
|
|
81
|
+
for (int i = 0; i < 32; ++i) {
|
|
82
|
+
if (mode & (1u << i)) {
|
|
83
|
+
printf("Unrecognized flag: %04x\n", (1u << i));
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return 0;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const auto verb = args[0];
|
|
90
|
+
|
|
91
|
+
if (verb == "set") {
|
|
92
|
+
if (args.size() == 2) {
|
|
93
|
+
const DWORD newMode = parseInt(args[1]);
|
|
94
|
+
setConsoleMode(newMode);
|
|
95
|
+
} else if (args.size() == 3) {
|
|
96
|
+
const DWORD mode = parseInt(args[1]);
|
|
97
|
+
const DWORD mask = parseInt(args[2]);
|
|
98
|
+
const int newMode = (getConsoleMode() & ~mask) | (mode & mask);
|
|
99
|
+
setConsoleMode(newMode);
|
|
100
|
+
} else {
|
|
101
|
+
usage();
|
|
102
|
+
}
|
|
103
|
+
} else if (verb == "get") {
|
|
104
|
+
if (args.size() != 1) {
|
|
105
|
+
usage();
|
|
106
|
+
}
|
|
107
|
+
printf("0x%lx\n", getConsoleMode());
|
|
108
|
+
} else {
|
|
109
|
+
usage();
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
return 0;
|
|
113
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
#!python
|
|
2
|
+
# Run with native CPython. Needs pywin32 extensions.
|
|
3
|
+
|
|
4
|
+
# Copyright (c) 2011-2012 Ryan Prichard
|
|
5
|
+
#
|
|
6
|
+
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
7
|
+
# of this software and associated documentation files (the "Software"), to
|
|
8
|
+
# deal in the Software without restriction, including without limitation the
|
|
9
|
+
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
10
|
+
# sell copies of the Software, and to permit persons to whom the Software is
|
|
11
|
+
# furnished to do so, subject to the following conditions:
|
|
12
|
+
#
|
|
13
|
+
# The above copyright notice and this permission notice shall be included in
|
|
14
|
+
# all copies or substantial portions of the Software.
|
|
15
|
+
#
|
|
16
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
17
|
+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
18
|
+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
19
|
+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
20
|
+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
21
|
+
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
22
|
+
# IN THE SOFTWARE.
|
|
23
|
+
|
|
24
|
+
import winerror
|
|
25
|
+
import win32pipe
|
|
26
|
+
import win32file
|
|
27
|
+
import win32api
|
|
28
|
+
import sys
|
|
29
|
+
import pywintypes
|
|
30
|
+
import time
|
|
31
|
+
|
|
32
|
+
if len(sys.argv) != 2:
|
|
33
|
+
print("Usage: %s message" % sys.argv[0])
|
|
34
|
+
sys.exit(1)
|
|
35
|
+
|
|
36
|
+
message = "[%05.3f %s]: %s" % (time.time() % 100000, sys.argv[0], sys.argv[1])
|
|
37
|
+
|
|
38
|
+
win32pipe.CallNamedPipe(
|
|
39
|
+
"\\\\.\\pipe\\DebugServer",
|
|
40
|
+
message.encode(),
|
|
41
|
+
16,
|
|
42
|
+
win32pipe.NMPWAIT_WAIT_FOREVER)
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
#!python
|
|
2
|
+
#
|
|
3
|
+
# Run with native CPython. Needs pywin32 extensions.
|
|
4
|
+
|
|
5
|
+
# Copyright (c) 2011-2012 Ryan Prichard
|
|
6
|
+
#
|
|
7
|
+
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
8
|
+
# of this software and associated documentation files (the "Software"), to
|
|
9
|
+
# deal in the Software without restriction, including without limitation the
|
|
10
|
+
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
11
|
+
# sell copies of the Software, and to permit persons to whom the Software is
|
|
12
|
+
# furnished to do so, subject to the following conditions:
|
|
13
|
+
#
|
|
14
|
+
# The above copyright notice and this permission notice shall be included in
|
|
15
|
+
# all copies or substantial portions of the Software.
|
|
16
|
+
#
|
|
17
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
18
|
+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
19
|
+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
20
|
+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
21
|
+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
22
|
+
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
23
|
+
# IN THE SOFTWARE.
|
|
24
|
+
|
|
25
|
+
import win32pipe
|
|
26
|
+
import win32api
|
|
27
|
+
import win32file
|
|
28
|
+
import time
|
|
29
|
+
import threading
|
|
30
|
+
import sys
|
|
31
|
+
|
|
32
|
+
# A message may not be larger than this size.
|
|
33
|
+
MSG_SIZE=4096
|
|
34
|
+
|
|
35
|
+
serverPipe = win32pipe.CreateNamedPipe(
|
|
36
|
+
"\\\\.\\pipe\\DebugServer",
|
|
37
|
+
win32pipe.PIPE_ACCESS_DUPLEX,
|
|
38
|
+
win32pipe.PIPE_TYPE_MESSAGE | win32pipe.PIPE_READMODE_MESSAGE,
|
|
39
|
+
win32pipe.PIPE_UNLIMITED_INSTANCES,
|
|
40
|
+
MSG_SIZE,
|
|
41
|
+
MSG_SIZE,
|
|
42
|
+
10 * 1000,
|
|
43
|
+
None)
|
|
44
|
+
while True:
|
|
45
|
+
win32pipe.ConnectNamedPipe(serverPipe, None)
|
|
46
|
+
(ret, data) = win32file.ReadFile(serverPipe, MSG_SIZE)
|
|
47
|
+
print(data.decode())
|
|
48
|
+
sys.stdout.flush()
|
|
49
|
+
|
|
50
|
+
# The client uses CallNamedPipe to send its message. CallNamedPipe waits
|
|
51
|
+
# for a reply message. If I send a reply, however, using WriteFile, then
|
|
52
|
+
# sometimes WriteFile fails with:
|
|
53
|
+
# pywintypes.error: (232, 'WriteFile', 'The pipe is being closed.')
|
|
54
|
+
# I can't figure out how to write a strictly correct pipe server, but if
|
|
55
|
+
# I comment out the WriteFile line, then everything seems to work. I
|
|
56
|
+
# think the DisconnectNamedPipe call aborts the client's CallNamedPipe
|
|
57
|
+
# call normally.
|
|
58
|
+
|
|
59
|
+
try:
|
|
60
|
+
win32file.WriteFile(serverPipe, b'OK')
|
|
61
|
+
except:
|
|
62
|
+
pass
|
|
63
|
+
win32pipe.DisconnectNamedPipe(serverPipe)
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
Note regarding ENABLE_EXTENDED_FLAGS (2016-05-30)
|
|
2
|
+
|
|
3
|
+
There is a complicated interaction between the ENABLE_EXTENDED_FLAGS flag
|
|
4
|
+
and the ENABLE_QUICK_EDIT_MODE and ENABLE_INSERT_MODE flags (presumably for
|
|
5
|
+
backwards compatibility?). I studied the behavior on Windows 7 and Windows
|
|
6
|
+
10, with both the old and new consoles, and I didn't see any differences
|
|
7
|
+
between versions. Here's what I seemed to observe:
|
|
8
|
+
|
|
9
|
+
- The console has three flags internally:
|
|
10
|
+
- QuickEdit
|
|
11
|
+
- InsertMode
|
|
12
|
+
- ExtendedFlags
|
|
13
|
+
|
|
14
|
+
- SetConsoleMode psuedocode:
|
|
15
|
+
void SetConsoleMode(..., DWORD mode) {
|
|
16
|
+
ExtendedFlags = (mode & (ENABLE_EXTENDED_FLAGS
|
|
17
|
+
| ENABLE_QUICK_EDIT_MODE
|
|
18
|
+
| ENABLE_INSERT_MODE )) != 0;
|
|
19
|
+
if (ExtendedFlags) {
|
|
20
|
+
QuickEdit = (mode & ENABLE_QUICK_EDIT_MODE) != 0;
|
|
21
|
+
InsertMode = (mode & ENABLE_INSERT_MODE) != 0;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
- Setting QuickEdit or InsertMode from the properties dialog GUI does not
|
|
26
|
+
affect the ExtendedFlags setting -- it simply toggles the one flag.
|
|
27
|
+
|
|
28
|
+
- GetConsoleMode psuedocode:
|
|
29
|
+
GetConsoleMode(..., DWORD *result) {
|
|
30
|
+
if (ExtendedFlags) {
|
|
31
|
+
*result |= ENABLE_EXTENDED_FLAGS;
|
|
32
|
+
if (QuickEdit) { *result |= ENABLE_QUICK_EDIT_MODE; }
|
|
33
|
+
if (InsertMode) { *result |= ENABLE_INSERT_MODE; }
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
Effectively, the ExtendedFlags flags controls whether the other two flags
|
|
38
|
+
are visible/controlled by the user application. If they aren't visible,
|
|
39
|
+
though, there is no way for the user application to make them visible,
|
|
40
|
+
except by overwriting their values! Calling SetConsoleMode with just
|
|
41
|
+
ENABLE_EXTENDED_FLAGS would clear the extended flags we want to read.
|
|
42
|
+
|
|
43
|
+
Consequently, if a program temporarily alters the QuickEdit flag (e.g. to
|
|
44
|
+
enable mouse input), it cannot restore the original values of the QuickEdit
|
|
45
|
+
and InsertMode flags, UNLESS every other console program cooperates by
|
|
46
|
+
keeping the ExtendedFlags flag set.
|