@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,144 @@
|
|
|
1
|
+
Issues:
|
|
2
|
+
|
|
3
|
+
- Starting with the 14342 build, changing the font using
|
|
4
|
+
SetCurrentConsoleFontEx does not affect the window size. e.g. The content
|
|
5
|
+
itself will resize/redraw, but the window neither shrinks nor expands.
|
|
6
|
+
Presumably this is an oversight? It's almost a convenience; if a program
|
|
7
|
+
is going to resize the window anyway, then it's nice that the window size
|
|
8
|
+
contraints don't get in the way. Ordinarily, changing the font doesn't just
|
|
9
|
+
change the window size in pixels--it can also change the size as measured in
|
|
10
|
+
rows and columns.
|
|
11
|
+
|
|
12
|
+
- (Aside: in the 14342 build, there is also a bug with wmic.exe. Open a console
|
|
13
|
+
with more than 300 lines of screen buffer, then fill those lines with, e.g.,
|
|
14
|
+
dir /s. Then run wmic.exe. You won't be able to see the wmic.exe prompt.
|
|
15
|
+
If you query the screen buffer info somehow, you'll notice that the srWindow
|
|
16
|
+
is not contained within the dwSize. This breaks winpty's scraping, because
|
|
17
|
+
it's invalid.)
|
|
18
|
+
|
|
19
|
+
- In build 14316, with the Japanese locale, with the 437 code page, attempting
|
|
20
|
+
to set the Consolas font instead sets the Terminal (raster) font. It seems
|
|
21
|
+
to pick an appropriate vertical size.
|
|
22
|
+
|
|
23
|
+
- It seems necessary to specify "-family 0x36" for maximum reliability.
|
|
24
|
+
Setting the family to 0 almost always works, and specifying just -tt rarely
|
|
25
|
+
works.
|
|
26
|
+
|
|
27
|
+
Win7
|
|
28
|
+
English locale / 437 code page:
|
|
29
|
+
SetFont.exe -face Consolas -h 16 works
|
|
30
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
31
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
32
|
+
Japanese locale / 932 code page:
|
|
33
|
+
SetFont.exe -face Consolas -h 16 works
|
|
34
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
35
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
36
|
+
Japanese locale / 437 code page:
|
|
37
|
+
SetFont.exe -face Consolas -h 16 works
|
|
38
|
+
SetFont.exe -face Consolas -h 16 -tt unreliable
|
|
39
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
40
|
+
|
|
41
|
+
Win10 Build 10586
|
|
42
|
+
New console
|
|
43
|
+
Japanese locale / 437 code page:
|
|
44
|
+
SetFont.exe -face Consolas -h 16 works
|
|
45
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal instead
|
|
46
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
47
|
+
|
|
48
|
+
Win10 Build 14316
|
|
49
|
+
Old console
|
|
50
|
+
English locale / 437 code page:
|
|
51
|
+
SetFont.exe -face Consolas -h 16 works
|
|
52
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
53
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
54
|
+
Japanese locale / 932 code page:
|
|
55
|
+
SetFont.exe -face Consolas -h 16 works
|
|
56
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
57
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
58
|
+
Japanese locale / 437 code page:
|
|
59
|
+
SetFont.exe -face Consolas -h 16 works
|
|
60
|
+
SetFont.exe -face Consolas -h 16 -tt selected very small Consolas font
|
|
61
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
62
|
+
New console
|
|
63
|
+
English locale / 437 code page:
|
|
64
|
+
SetFont.exe -face Consolas -h 16 works
|
|
65
|
+
SetFont.exe -face Consolas -h 16 -tt works
|
|
66
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
67
|
+
Japanese locale / 932 code page:
|
|
68
|
+
SetFont.exe -face Consolas -h 16 selects gothic instead
|
|
69
|
+
SetFont.exe -face Consolas -h 16 -tt selects gothic instead
|
|
70
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 selects gothic instead
|
|
71
|
+
Japanese locale / 437 code page:
|
|
72
|
+
SetFont.exe -face Consolas -h 16 selects Terminal font instead
|
|
73
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
74
|
+
SetFont.exe -face Consolas -h 16 -family 0x36(*) selects Terminal font instead
|
|
75
|
+
|
|
76
|
+
Win10 Build 14342
|
|
77
|
+
Old Console
|
|
78
|
+
English locale / 437 code page:
|
|
79
|
+
SetFont.exe -face Consolas -h 16 works
|
|
80
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
81
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
82
|
+
Japanese locale / 932 code page:
|
|
83
|
+
SetFont.exe -face Consolas -h 16 works
|
|
84
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
85
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
86
|
+
Japanese locale / 437 code page:
|
|
87
|
+
SetFont.exe -face Consolas -h 16 works
|
|
88
|
+
SetFont.exe -face Consolas -h 16 -tt selects Terminal font instead
|
|
89
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
90
|
+
New console
|
|
91
|
+
English locale / 437 code page:
|
|
92
|
+
SetFont.exe -face Consolas -h 16 works
|
|
93
|
+
SetFont.exe -face Consolas -h 16 -tt works
|
|
94
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
95
|
+
Japanese locale / 932 code page:
|
|
96
|
+
SetFont.exe -face Consolas -h 16 selects gothic instead
|
|
97
|
+
SetFont.exe -face Consolas -h 16 -tt selects gothic instead
|
|
98
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 selects gothic instead
|
|
99
|
+
Japanese locale / 437 code page:
|
|
100
|
+
SetFont.exe -face Consolas -h 16 selects Terminal font instead
|
|
101
|
+
SetFont.exe -face Consolas -h 16 -tt works
|
|
102
|
+
SetFont.exe -face Consolas -h 16 -family 0x36 works
|
|
103
|
+
|
|
104
|
+
(*) I was trying to figure out whether the inconsistency was at when I stumbled
|
|
105
|
+
onto this completely unexpected bug. Here's more detail:
|
|
106
|
+
|
|
107
|
+
F:\>SetFont.exe -face Consolas -h 16 -family 0x36 -weight normal -w 8
|
|
108
|
+
Setting to: nFont=0 dwFontSize=(8,16) FontFamily=0x36 FontWeight=400 FaceName="Consolas"
|
|
109
|
+
SetCurrentConsoleFontEx returned 1
|
|
110
|
+
|
|
111
|
+
F:\>GetFont.exe
|
|
112
|
+
largestConsoleWindowSize=(96,50)
|
|
113
|
+
maxWnd=0: nFont=0 dwFontSize=(12,16) FontFamily=0x30 FontWeight=400 FaceName=Terminal (54 65 72 6D 69 6E 61 6C)
|
|
114
|
+
maxWnd=1: nFont=0 dwFontSize=(96,25) FontFamily=0x30 FontWeight=400 FaceName=Terminal (54 65 72 6D 69 6E 61 6C)
|
|
115
|
+
00-00: 12x16
|
|
116
|
+
GetNumberOfConsoleFonts returned 0
|
|
117
|
+
CP=437 OutputCP=437
|
|
118
|
+
|
|
119
|
+
F:\>SetFont.exe -face "Lucida Console" -h 16 -family 0x36 -weight normal
|
|
120
|
+
Setting to: nFont=0 dwFontSize=(0,16) FontFamily=0x36 FontWeight=400 FaceName="Lucida Console"
|
|
121
|
+
SetCurrentConsoleFontEx returned 1
|
|
122
|
+
|
|
123
|
+
F:\>GetFont.exe
|
|
124
|
+
largestConsoleWindowSize=(96,50)
|
|
125
|
+
maxWnd=0: nFont=0 dwFontSize=(12,16) FontFamily=0x30 FontWeight=400 FaceName=Terminal (54 65 72 6D 69 6E 61 6C)
|
|
126
|
+
maxWnd=1: nFont=0 dwFontSize=(96,25) FontFamily=0x30 FontWeight=400 FaceName=Terminal (54 65 72 6D 69 6E 61 6C)
|
|
127
|
+
00-00: 12x16
|
|
128
|
+
GetNumberOfConsoleFonts returned 0
|
|
129
|
+
CP=437 OutputCP=437
|
|
130
|
+
|
|
131
|
+
F:\>SetFont.exe -face "Lucida Console" -h 12 -family 0x36 -weight normal
|
|
132
|
+
Setting to: nFont=0 dwFontSize=(0,12) FontFamily=0x36 FontWeight=400 FaceName="Lucida Console"
|
|
133
|
+
SetCurrentConsoleFontEx returned 1
|
|
134
|
+
|
|
135
|
+
F:\>GetFont.exe
|
|
136
|
+
largestConsoleWindowSize=(230,66)
|
|
137
|
+
maxWnd=0: nFont=0 dwFontSize=(5,12) FontFamily=0x30 FontWeight=400 FaceName=Terminal (54 65 72 6D 69 6E 61 6C)
|
|
138
|
+
maxWnd=1: nFont=0 dwFontSize=(116,36) FontFamily=0x30 FontWeight=400 FaceName=Terminal (54 65 72 6D 69 6E 61 6C)
|
|
139
|
+
00-00: 5x12
|
|
140
|
+
GetNumberOfConsoleFonts returned 0
|
|
141
|
+
CP=437 OutputCP=437
|
|
142
|
+
|
|
143
|
+
Even attempting to set to a Lucida Console / Consolas font from the Console
|
|
144
|
+
properties dialog fails.
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
#include <windows.h>
|
|
2
|
+
|
|
3
|
+
#include <stdio.h>
|
|
4
|
+
#include <stdlib.h>
|
|
5
|
+
#include <string.h>
|
|
6
|
+
|
|
7
|
+
#include <vector>
|
|
8
|
+
|
|
9
|
+
#include "TestUtil.cc"
|
|
10
|
+
|
|
11
|
+
#define COUNT_OF(array) (sizeof(array) / sizeof((array)[0]))
|
|
12
|
+
|
|
13
|
+
// See https://en.wikipedia.org/wiki/List_of_CJK_fonts
|
|
14
|
+
const wchar_t kMSGothic[] = { 0xff2d, 0xff33, 0x0020, 0x30b4, 0x30b7, 0x30c3, 0x30af, 0 }; // Japanese
|
|
15
|
+
const wchar_t kNSimSun[] = { 0x65b0, 0x5b8b, 0x4f53, 0 }; // Simplified Chinese
|
|
16
|
+
const wchar_t kMingLight[] = { 0x7d30, 0x660e, 0x9ad4, 0 }; // Traditional Chinese
|
|
17
|
+
const wchar_t kGulimChe[] = { 0xad74, 0xb9bc, 0xccb4, 0 }; // Korean
|
|
18
|
+
|
|
19
|
+
std::vector<bool> condense(const std::vector<CHAR_INFO> &buf) {
|
|
20
|
+
std::vector<bool> ret;
|
|
21
|
+
size_t i = 0;
|
|
22
|
+
while (i < buf.size()) {
|
|
23
|
+
if (buf[i].Char.UnicodeChar == L' ' &&
|
|
24
|
+
((buf[i].Attributes & 0x300) == 0)) {
|
|
25
|
+
// end of line
|
|
26
|
+
break;
|
|
27
|
+
} else if (i + 1 < buf.size() &&
|
|
28
|
+
((buf[i].Attributes & 0x300) == 0x100) &&
|
|
29
|
+
((buf[i + 1].Attributes & 0x300) == 0x200) &&
|
|
30
|
+
buf[i].Char.UnicodeChar != L' ' &&
|
|
31
|
+
buf[i].Char.UnicodeChar == buf[i + 1].Char.UnicodeChar) {
|
|
32
|
+
// double-width
|
|
33
|
+
ret.push_back(true);
|
|
34
|
+
i += 2;
|
|
35
|
+
} else if ((buf[i].Attributes & 0x300) == 0) {
|
|
36
|
+
// single-width
|
|
37
|
+
ret.push_back(false);
|
|
38
|
+
i++;
|
|
39
|
+
} else {
|
|
40
|
+
ASSERT(false && "unexpected output");
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
return ret;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
int main(int argc, char *argv[]) {
|
|
47
|
+
if (argc != 2) {
|
|
48
|
+
printf("Usage: %s \"arguments for SetFont.exe\"\n", argv[0]);
|
|
49
|
+
return 1;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const char *setFontArgs = argv[1];
|
|
53
|
+
|
|
54
|
+
const wchar_t testLine[] = { 0xA2, 0xA3, 0x2014, 0x3044, 0x30FC, 0x4000, 0 };
|
|
55
|
+
const HANDLE conout = openConout();
|
|
56
|
+
|
|
57
|
+
char setFontCmd[1024];
|
|
58
|
+
for (int h = 1; h <= 100; ++h) {
|
|
59
|
+
sprintf(setFontCmd, ".\\SetFont.exe %s -h %d && cls", setFontArgs, h);
|
|
60
|
+
system(setFontCmd);
|
|
61
|
+
|
|
62
|
+
CONSOLE_FONT_INFOEX infoex = {};
|
|
63
|
+
infoex.cbSize = sizeof(infoex);
|
|
64
|
+
BOOL success = GetCurrentConsoleFontEx(conout, FALSE, &infoex);
|
|
65
|
+
ASSERT(success && "GetCurrentConsoleFontEx failed");
|
|
66
|
+
|
|
67
|
+
DWORD actual = 0;
|
|
68
|
+
success = WriteConsoleW(conout, testLine, wcslen(testLine), &actual, nullptr);
|
|
69
|
+
ASSERT(success && actual == wcslen(testLine));
|
|
70
|
+
|
|
71
|
+
std::vector<CHAR_INFO> readBuf(14);
|
|
72
|
+
const SMALL_RECT readRegion = {0, 0, static_cast<short>(readBuf.size() - 1), 0};
|
|
73
|
+
SMALL_RECT readRegion2 = readRegion;
|
|
74
|
+
success = ReadConsoleOutputW(
|
|
75
|
+
conout, readBuf.data(),
|
|
76
|
+
{static_cast<short>(readBuf.size()), 1},
|
|
77
|
+
{0, 0},
|
|
78
|
+
&readRegion2);
|
|
79
|
+
ASSERT(success && !memcmp(&readRegion, &readRegion2, sizeof(readRegion)));
|
|
80
|
+
|
|
81
|
+
const auto widths = condense(readBuf);
|
|
82
|
+
std::string widthsStr;
|
|
83
|
+
for (bool width : widths) {
|
|
84
|
+
widthsStr.append(width ? "F" : "H");
|
|
85
|
+
}
|
|
86
|
+
char size[16];
|
|
87
|
+
sprintf(size, "%d,%d", infoex.dwFontSize.X, infoex.dwFontSize.Y);
|
|
88
|
+
const char *status = "";
|
|
89
|
+
if (widthsStr == "HHFFFF") {
|
|
90
|
+
status = "GOOD";
|
|
91
|
+
} else if (widthsStr == "HHHFFF") {
|
|
92
|
+
status = "OK";
|
|
93
|
+
} else {
|
|
94
|
+
status = "BAD";
|
|
95
|
+
}
|
|
96
|
+
trace("Size %3d: %-7s %-4s (%s)", h, size, status, widthsStr.c_str());
|
|
97
|
+
}
|
|
98
|
+
sprintf(setFontCmd, ".\\SetFont.exe %s -h 14", setFontArgs);
|
|
99
|
+
system(setFontCmd);
|
|
100
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#include <ctype.h>
|
|
2
|
+
#include <stdio.h>
|
|
3
|
+
#include <string.h>
|
|
4
|
+
|
|
5
|
+
static inline void formatChar(char *str, char ch)
|
|
6
|
+
{
|
|
7
|
+
// Print some common control codes.
|
|
8
|
+
switch (ch) {
|
|
9
|
+
case '\r': strcpy(str, "CR "); break;
|
|
10
|
+
case '\n': strcpy(str, "LF "); break;
|
|
11
|
+
case ' ': strcpy(str, "SP "); break;
|
|
12
|
+
case 27: strcpy(str, "^[ "); break;
|
|
13
|
+
case 3: strcpy(str, "^C "); break;
|
|
14
|
+
default:
|
|
15
|
+
if (isgraph(ch))
|
|
16
|
+
sprintf(str, "%c ", ch);
|
|
17
|
+
else
|
|
18
|
+
sprintf(str, "%02x ", ch);
|
|
19
|
+
break;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
#include <windows.h>
|
|
2
|
+
|
|
3
|
+
#include "TestUtil.cc"
|
|
4
|
+
|
|
5
|
+
const int SC_CONSOLE_MARK = 0xFFF2;
|
|
6
|
+
const int SC_CONSOLE_SELECT_ALL = 0xFFF5;
|
|
7
|
+
|
|
8
|
+
int main(int argc, char *argv[0]) {
|
|
9
|
+
|
|
10
|
+
if (argc != 2) {
|
|
11
|
+
printf("Usage: %s (mark|selectall|read)\n", argv[0]);
|
|
12
|
+
return 1;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
enum class Test { Mark, SelectAll, Read } test;
|
|
16
|
+
if (!strcmp(argv[1], "mark")) {
|
|
17
|
+
test = Test::Mark;
|
|
18
|
+
} else if (!strcmp(argv[1], "selectall")) {
|
|
19
|
+
test = Test::SelectAll;
|
|
20
|
+
} else if (!strcmp(argv[1], "read")) {
|
|
21
|
+
test = Test::Read;
|
|
22
|
+
} else {
|
|
23
|
+
printf("Invalid test: %s\n", argv[1]);
|
|
24
|
+
return 1;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
HANDLE conout = GetStdHandle(STD_OUTPUT_HANDLE);
|
|
28
|
+
TimeMeasurement tm;
|
|
29
|
+
HWND hwnd = GetConsoleWindow();
|
|
30
|
+
|
|
31
|
+
setWindowPos(0, 0, 1, 1);
|
|
32
|
+
setBufferSize(100, 3000);
|
|
33
|
+
system("cls");
|
|
34
|
+
setWindowPos(0, 2975, 100, 25);
|
|
35
|
+
setCursorPos(0, 2999);
|
|
36
|
+
|
|
37
|
+
ShowWindow(hwnd, SW_HIDE);
|
|
38
|
+
|
|
39
|
+
for (int i = 0; i < 1000; ++i) {
|
|
40
|
+
// CONSOLE_SCREEN_BUFFER_INFO info = {};
|
|
41
|
+
// GetConsoleScreenBufferInfo(conout, &info);
|
|
42
|
+
|
|
43
|
+
if (test == Test::Mark) {
|
|
44
|
+
SendMessage(hwnd, WM_SYSCOMMAND, SC_CONSOLE_MARK, 0);
|
|
45
|
+
SendMessage(hwnd, WM_CHAR, 27, 0x00010001);
|
|
46
|
+
} else if (test == Test::SelectAll) {
|
|
47
|
+
SendMessage(hwnd, WM_SYSCOMMAND, SC_CONSOLE_SELECT_ALL, 0);
|
|
48
|
+
SendMessage(hwnd, WM_CHAR, 27, 0x00010001);
|
|
49
|
+
} else if (test == Test::Read) {
|
|
50
|
+
static CHAR_INFO buffer[100 * 3000];
|
|
51
|
+
const SMALL_RECT readRegion = {0, 0, 99, 2999};
|
|
52
|
+
SMALL_RECT tmp = readRegion;
|
|
53
|
+
BOOL ret = ReadConsoleOutput(conout, buffer, {100, 3000}, {0, 0}, &tmp);
|
|
54
|
+
ASSERT(ret && !memcmp(&tmp, &readRegion, sizeof(tmp)));
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
ShowWindow(hwnd, SW_SHOW);
|
|
59
|
+
|
|
60
|
+
printf("elapsed: %f\n", tm.elapsed());
|
|
61
|
+
return 0;
|
|
62
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
#include <conio.h>
|
|
2
|
+
#include <ctype.h>
|
|
3
|
+
#include <stdio.h>
|
|
4
|
+
|
|
5
|
+
int main() {
|
|
6
|
+
printf("\nPress any keys -- Ctrl-D exits\n\n");
|
|
7
|
+
|
|
8
|
+
while (true) {
|
|
9
|
+
const int ch = getch();
|
|
10
|
+
printf("0x%x", ch);
|
|
11
|
+
if (isgraph(ch)) {
|
|
12
|
+
printf(" '%c'", ch);
|
|
13
|
+
}
|
|
14
|
+
printf("\n");
|
|
15
|
+
if (ch == 0x4) { // Ctrl-D
|
|
16
|
+
break;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
return 0;
|
|
20
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
#include <windows.h>
|
|
2
|
+
|
|
3
|
+
#include <stdio.h>
|
|
4
|
+
|
|
5
|
+
#include "TestUtil.cc"
|
|
6
|
+
|
|
7
|
+
int main() {
|
|
8
|
+
const HANDLE conout = openConout();
|
|
9
|
+
|
|
10
|
+
CONSOLE_SCREEN_BUFFER_INFO info = {};
|
|
11
|
+
BOOL ret = GetConsoleScreenBufferInfo(conout, &info);
|
|
12
|
+
ASSERT(ret && "GetConsoleScreenBufferInfo failed");
|
|
13
|
+
|
|
14
|
+
trace("cursor=%d,%d", info.dwCursorPosition.X, info.dwCursorPosition.Y);
|
|
15
|
+
printf("cursor=%d,%d\n", info.dwCursorPosition.X, info.dwCursorPosition.Y);
|
|
16
|
+
|
|
17
|
+
trace("srWindow={L=%d,T=%d,R=%d,B=%d}", info.srWindow.Left, info.srWindow.Top, info.srWindow.Right, info.srWindow.Bottom);
|
|
18
|
+
printf("srWindow={L=%d,T=%d,R=%d,B=%d}\n", info.srWindow.Left, info.srWindow.Top, info.srWindow.Right, info.srWindow.Bottom);
|
|
19
|
+
|
|
20
|
+
trace("dwSize=%d,%d", info.dwSize.X, info.dwSize.Y);
|
|
21
|
+
printf("dwSize=%d,%d\n", info.dwSize.X, info.dwSize.Y);
|
|
22
|
+
|
|
23
|
+
const HWND hwnd = GetConsoleWindow();
|
|
24
|
+
if (hwnd != NULL) {
|
|
25
|
+
RECT r = {};
|
|
26
|
+
if (GetWindowRect(hwnd, &r)) {
|
|
27
|
+
const int w = r.right - r.left;
|
|
28
|
+
const int h = r.bottom - r.top;
|
|
29
|
+
trace("hwnd: pos=(%d,%d) size=(%d,%d)", r.left, r.top, w, h);
|
|
30
|
+
printf("hwnd: pos=(%d,%d) size=(%d,%d)\n", r.left, r.top, w, h);
|
|
31
|
+
} else {
|
|
32
|
+
trace("GetWindowRect failed");
|
|
33
|
+
printf("GetWindowRect failed\n");
|
|
34
|
+
}
|
|
35
|
+
} else {
|
|
36
|
+
trace("GetConsoleWindow returned NULL");
|
|
37
|
+
printf("GetConsoleWindow returned NULL\n");
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
return 0;
|
|
41
|
+
}
|
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
#include <windows.h>
|
|
2
|
+
#include <stdio.h>
|
|
3
|
+
#include <stdarg.h>
|
|
4
|
+
#include <wchar.h>
|
|
5
|
+
|
|
6
|
+
#include "../src/shared/OsModule.h"
|
|
7
|
+
#include "../src/shared/StringUtil.h"
|
|
8
|
+
|
|
9
|
+
#include "TestUtil.cc"
|
|
10
|
+
#include "../src/shared/StringUtil.cc"
|
|
11
|
+
|
|
12
|
+
#define COUNT_OF(x) (sizeof(x) / sizeof((x)[0]))
|
|
13
|
+
|
|
14
|
+
// Some of these types and functions are missing from the MinGW headers.
|
|
15
|
+
// Others are undocumented.
|
|
16
|
+
|
|
17
|
+
struct AGENT_CONSOLE_FONT_INFO {
|
|
18
|
+
DWORD nFont;
|
|
19
|
+
COORD dwFontSize;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
struct AGENT_CONSOLE_FONT_INFOEX {
|
|
23
|
+
ULONG cbSize;
|
|
24
|
+
DWORD nFont;
|
|
25
|
+
COORD dwFontSize;
|
|
26
|
+
UINT FontFamily;
|
|
27
|
+
UINT FontWeight;
|
|
28
|
+
WCHAR FaceName[LF_FACESIZE];
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
// undocumented XP API
|
|
32
|
+
typedef BOOL WINAPI SetConsoleFont_t(
|
|
33
|
+
HANDLE hOutput,
|
|
34
|
+
DWORD dwFontIndex);
|
|
35
|
+
|
|
36
|
+
// undocumented XP API
|
|
37
|
+
typedef DWORD WINAPI GetNumberOfConsoleFonts_t();
|
|
38
|
+
|
|
39
|
+
// XP and up
|
|
40
|
+
typedef BOOL WINAPI GetCurrentConsoleFont_t(
|
|
41
|
+
HANDLE hOutput,
|
|
42
|
+
BOOL bMaximumWindow,
|
|
43
|
+
AGENT_CONSOLE_FONT_INFO *lpConsoleCurrentFont);
|
|
44
|
+
|
|
45
|
+
// XP and up
|
|
46
|
+
typedef COORD WINAPI GetConsoleFontSize_t(
|
|
47
|
+
HANDLE hConsoleOutput,
|
|
48
|
+
DWORD nFont);
|
|
49
|
+
|
|
50
|
+
// Vista and up
|
|
51
|
+
typedef BOOL WINAPI GetCurrentConsoleFontEx_t(
|
|
52
|
+
HANDLE hConsoleOutput,
|
|
53
|
+
BOOL bMaximumWindow,
|
|
54
|
+
AGENT_CONSOLE_FONT_INFOEX *lpConsoleCurrentFontEx);
|
|
55
|
+
|
|
56
|
+
// Vista and up
|
|
57
|
+
typedef BOOL WINAPI SetCurrentConsoleFontEx_t(
|
|
58
|
+
HANDLE hConsoleOutput,
|
|
59
|
+
BOOL bMaximumWindow,
|
|
60
|
+
AGENT_CONSOLE_FONT_INFOEX *lpConsoleCurrentFontEx);
|
|
61
|
+
|
|
62
|
+
#define GET_MODULE_PROC(mod, funcName) \
|
|
63
|
+
m_##funcName = reinterpret_cast<funcName##_t*>((mod).proc(#funcName)); \
|
|
64
|
+
|
|
65
|
+
#define DEFINE_ACCESSOR(funcName) \
|
|
66
|
+
funcName##_t &funcName() const { \
|
|
67
|
+
ASSERT(valid()); \
|
|
68
|
+
return *m_##funcName; \
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
class XPFontAPI {
|
|
72
|
+
public:
|
|
73
|
+
XPFontAPI() : m_kernel32(L"kernel32.dll") {
|
|
74
|
+
GET_MODULE_PROC(m_kernel32, GetCurrentConsoleFont);
|
|
75
|
+
GET_MODULE_PROC(m_kernel32, GetConsoleFontSize);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
bool valid() const {
|
|
79
|
+
return m_GetCurrentConsoleFont != NULL &&
|
|
80
|
+
m_GetConsoleFontSize != NULL;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
DEFINE_ACCESSOR(GetCurrentConsoleFont)
|
|
84
|
+
DEFINE_ACCESSOR(GetConsoleFontSize)
|
|
85
|
+
|
|
86
|
+
private:
|
|
87
|
+
OsModule m_kernel32;
|
|
88
|
+
GetCurrentConsoleFont_t *m_GetCurrentConsoleFont;
|
|
89
|
+
GetConsoleFontSize_t *m_GetConsoleFontSize;
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
class UndocumentedXPFontAPI : public XPFontAPI {
|
|
93
|
+
public:
|
|
94
|
+
UndocumentedXPFontAPI() : m_kernel32(L"kernel32.dll") {
|
|
95
|
+
GET_MODULE_PROC(m_kernel32, SetConsoleFont);
|
|
96
|
+
GET_MODULE_PROC(m_kernel32, GetNumberOfConsoleFonts);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
bool valid() const {
|
|
100
|
+
return this->XPFontAPI::valid() &&
|
|
101
|
+
m_SetConsoleFont != NULL &&
|
|
102
|
+
m_GetNumberOfConsoleFonts != NULL;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
DEFINE_ACCESSOR(SetConsoleFont)
|
|
106
|
+
DEFINE_ACCESSOR(GetNumberOfConsoleFonts)
|
|
107
|
+
|
|
108
|
+
private:
|
|
109
|
+
OsModule m_kernel32;
|
|
110
|
+
SetConsoleFont_t *m_SetConsoleFont;
|
|
111
|
+
GetNumberOfConsoleFonts_t *m_GetNumberOfConsoleFonts;
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
class VistaFontAPI : public XPFontAPI {
|
|
115
|
+
public:
|
|
116
|
+
VistaFontAPI() : m_kernel32(L"kernel32.dll") {
|
|
117
|
+
GET_MODULE_PROC(m_kernel32, GetCurrentConsoleFontEx);
|
|
118
|
+
GET_MODULE_PROC(m_kernel32, SetCurrentConsoleFontEx);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
bool valid() const {
|
|
122
|
+
return this->XPFontAPI::valid() &&
|
|
123
|
+
m_GetCurrentConsoleFontEx != NULL &&
|
|
124
|
+
m_SetCurrentConsoleFontEx != NULL;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
DEFINE_ACCESSOR(GetCurrentConsoleFontEx)
|
|
128
|
+
DEFINE_ACCESSOR(SetCurrentConsoleFontEx)
|
|
129
|
+
|
|
130
|
+
private:
|
|
131
|
+
OsModule m_kernel32;
|
|
132
|
+
GetCurrentConsoleFontEx_t *m_GetCurrentConsoleFontEx;
|
|
133
|
+
SetCurrentConsoleFontEx_t *m_SetCurrentConsoleFontEx;
|
|
134
|
+
};
|
|
135
|
+
|
|
136
|
+
static std::vector<std::pair<DWORD, COORD> > readFontTable(
|
|
137
|
+
XPFontAPI &api, HANDLE conout, DWORD maxCount) {
|
|
138
|
+
std::vector<std::pair<DWORD, COORD> > ret;
|
|
139
|
+
for (DWORD i = 0; i < maxCount; ++i) {
|
|
140
|
+
COORD size = api.GetConsoleFontSize()(conout, i);
|
|
141
|
+
if (size.X == 0 && size.Y == 0) {
|
|
142
|
+
break;
|
|
143
|
+
}
|
|
144
|
+
ret.push_back(std::make_pair(i, size));
|
|
145
|
+
}
|
|
146
|
+
return ret;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
static void dumpFontTable(HANDLE conout) {
|
|
150
|
+
const int kMaxCount = 1000;
|
|
151
|
+
XPFontAPI api;
|
|
152
|
+
if (!api.valid()) {
|
|
153
|
+
printf("dumpFontTable: cannot dump font table -- missing APIs\n");
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
std::vector<std::pair<DWORD, COORD> > table =
|
|
157
|
+
readFontTable(api, conout, kMaxCount);
|
|
158
|
+
std::string line;
|
|
159
|
+
char tmp[128];
|
|
160
|
+
size_t first = 0;
|
|
161
|
+
while (first < table.size()) {
|
|
162
|
+
size_t last = std::min(table.size() - 1, first + 10 - 1);
|
|
163
|
+
winpty_snprintf(tmp, "%02u-%02u:",
|
|
164
|
+
static_cast<unsigned>(first), static_cast<unsigned>(last));
|
|
165
|
+
line = tmp;
|
|
166
|
+
for (size_t i = first; i <= last; ++i) {
|
|
167
|
+
if (i % 10 == 5) {
|
|
168
|
+
line += " - ";
|
|
169
|
+
}
|
|
170
|
+
winpty_snprintf(tmp, " %2dx%-2d",
|
|
171
|
+
table[i].second.X, table[i].second.Y);
|
|
172
|
+
line += tmp;
|
|
173
|
+
}
|
|
174
|
+
printf("%s\n", line.c_str());
|
|
175
|
+
first = last + 1;
|
|
176
|
+
}
|
|
177
|
+
if (table.size() == kMaxCount) {
|
|
178
|
+
printf("... stopped reading at %d fonts ...\n", kMaxCount);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
static std::string stringToCodePoints(const std::wstring &str) {
|
|
183
|
+
std::string ret = "(";
|
|
184
|
+
for (size_t i = 0; i < str.size(); ++i) {
|
|
185
|
+
char tmp[32];
|
|
186
|
+
winpty_snprintf(tmp, "%X", str[i]);
|
|
187
|
+
if (ret.size() > 1) {
|
|
188
|
+
ret.push_back(' ');
|
|
189
|
+
}
|
|
190
|
+
ret += tmp;
|
|
191
|
+
}
|
|
192
|
+
ret.push_back(')');
|
|
193
|
+
return ret;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
static void dumpFontInfoEx(
|
|
197
|
+
const AGENT_CONSOLE_FONT_INFOEX &infoex) {
|
|
198
|
+
std::wstring faceName(infoex.FaceName,
|
|
199
|
+
winpty_wcsnlen(infoex.FaceName, COUNT_OF(infoex.FaceName)));
|
|
200
|
+
cprintf(L"nFont=%u dwFontSize=(%d,%d) "
|
|
201
|
+
"FontFamily=0x%x FontWeight=%u FaceName=%ls %hs\n",
|
|
202
|
+
static_cast<unsigned>(infoex.nFont),
|
|
203
|
+
infoex.dwFontSize.X, infoex.dwFontSize.Y,
|
|
204
|
+
infoex.FontFamily, infoex.FontWeight, faceName.c_str(),
|
|
205
|
+
stringToCodePoints(faceName).c_str());
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
static void dumpVistaFont(VistaFontAPI &api, HANDLE conout, BOOL maxWindow) {
|
|
209
|
+
AGENT_CONSOLE_FONT_INFOEX infoex = {0};
|
|
210
|
+
infoex.cbSize = sizeof(infoex);
|
|
211
|
+
if (!api.GetCurrentConsoleFontEx()(conout, maxWindow, &infoex)) {
|
|
212
|
+
printf("GetCurrentConsoleFontEx call failed\n");
|
|
213
|
+
return;
|
|
214
|
+
}
|
|
215
|
+
dumpFontInfoEx(infoex);
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
static void dumpXPFont(XPFontAPI &api, HANDLE conout, BOOL maxWindow) {
|
|
219
|
+
AGENT_CONSOLE_FONT_INFO info = {0};
|
|
220
|
+
if (!api.GetCurrentConsoleFont()(conout, maxWindow, &info)) {
|
|
221
|
+
printf("GetCurrentConsoleFont call failed\n");
|
|
222
|
+
return;
|
|
223
|
+
}
|
|
224
|
+
printf("nFont=%u dwFontSize=(%d,%d)\n",
|
|
225
|
+
static_cast<unsigned>(info.nFont),
|
|
226
|
+
info.dwFontSize.X, info.dwFontSize.Y);
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
static void dumpFontAndTable(HANDLE conout) {
|
|
230
|
+
VistaFontAPI vista;
|
|
231
|
+
if (vista.valid()) {
|
|
232
|
+
printf("maxWnd=0: "); dumpVistaFont(vista, conout, FALSE);
|
|
233
|
+
printf("maxWnd=1: "); dumpVistaFont(vista, conout, TRUE);
|
|
234
|
+
dumpFontTable(conout);
|
|
235
|
+
return;
|
|
236
|
+
}
|
|
237
|
+
UndocumentedXPFontAPI xp;
|
|
238
|
+
if (xp.valid()) {
|
|
239
|
+
printf("maxWnd=0: "); dumpXPFont(xp, conout, FALSE);
|
|
240
|
+
printf("maxWnd=1: "); dumpXPFont(xp, conout, TRUE);
|
|
241
|
+
dumpFontTable(conout);
|
|
242
|
+
return;
|
|
243
|
+
}
|
|
244
|
+
printf("setSmallFont: neither Vista nor XP APIs detected -- giving up\n");
|
|
245
|
+
dumpFontTable(conout);
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
int main() {
|
|
249
|
+
const HANDLE conout = openConout();
|
|
250
|
+
const COORD largest = GetLargestConsoleWindowSize(conout);
|
|
251
|
+
printf("largestConsoleWindowSize=(%d,%d)\n", largest.X, largest.Y);
|
|
252
|
+
dumpFontAndTable(conout);
|
|
253
|
+
UndocumentedXPFontAPI xp;
|
|
254
|
+
if (xp.valid()) {
|
|
255
|
+
printf("GetNumberOfConsoleFonts returned %u\n", xp.GetNumberOfConsoleFonts()());
|
|
256
|
+
} else {
|
|
257
|
+
printf("The GetNumberOfConsoleFonts API was missing\n");
|
|
258
|
+
}
|
|
259
|
+
printf("CP=%u OutputCP=%u\n", GetConsoleCP(), GetConsoleOutputCP());
|
|
260
|
+
return 0;
|
|
261
|
+
}
|