2 * COPYRIGHT: See COPYING in the top level directory
3 * PROJECT: ReactOS Console Server DLL
4 * FILE: include/reactos/subsys/win/conmsg.h
5 * PURPOSE: Public definitions for communication
6 * between Console API Clients and Servers
7 * PROGRAMMERS: Hermes Belusca-Maito (hermes.belusca@sfr.fr)
15 #define CONSRV_SERVERDLL_INDEX 2
16 #define CONSRV_FIRST_API_NUMBER 512
18 // Windows Server 2003 table from http://j00ru.vexillium.org/csrss_list/api_list.html#Windows_2k3
19 typedef enum _CONSRV_API_NUMBER
21 ConsolepOpenConsole
= CONSRV_FIRST_API_NUMBER
,
22 ConsolepGetConsoleInput
,
23 ConsolepWriteConsoleInput
,
24 ConsolepReadConsoleOutput
,
25 ConsolepWriteConsoleOutput
,
26 ConsolepReadConsoleOutputString
,
27 ConsolepWriteConsoleOutputString
,
28 ConsolepFillConsoleOutput
,
30 ConsolepGetNumberOfFonts
,
31 ConsolepGetNumberOfInputEvents
,
32 ConsolepGetScreenBufferInfo
,
33 ConsolepGetCursorInfo
,
37 ConsolepGetCurrentFont
,
39 ConsolepSetActiveScreenBuffer
,
40 ConsolepFlushInputBuffer
,
41 ConsolepGetLargestWindowSize
,
42 ConsolepSetScreenBufferSize
,
43 ConsolepSetCursorPosition
,
44 ConsolepSetCursorInfo
,
45 ConsolepSetWindowInfo
,
46 ConsolepScrollScreenBuffer
,
47 ConsolepSetTextAttribute
,
52 ConsolepDuplicateHandle
,
53 ConsolepGetHandleInformation
,
54 ConsolepSetHandleInformation
,
56 ConsolepVerifyIoHandle
,
57 ConsolepAlloc
, // Not present in Win7
58 ConsolepFree
, // Not present in Win7
61 ConsolepCreateScreenBuffer
,
62 ConsolepInvalidateBitMapRect
,
68 ConsolepSetDisplayMode
,
70 ConsolepGetHardwareState
,
71 ConsolepSetHardwareState
,
72 ConsolepGetDisplayMode
,
75 ConsolepGetAliasesLength
,
76 ConsolepGetAliasExesLength
,
79 ConsolepExpungeCommandHistory
,
80 ConsolepSetNumberOfCommands
,
81 ConsolepGetCommandHistoryLength
,
82 ConsolepGetCommandHistory
,
83 ConsolepSetCommandHistoryMode
, // Not present in Vista+
86 ConsolepSetKeyShortcuts
,
88 ConsolepNotifyLastClose
,
89 ConsolepGenerateCtrlEvent
,
90 ConsolepGetKeyboardLayoutName
,
91 ConsolepGetConsoleWindow
,
94 ConsolepSetCursorMode
,
95 ConsolepGetCursorMode
,
97 ConsolepSetOS2OemFormat
,
100 ConsolepRegisterConsoleIME
, // Not present in Win7
101 ConsolepUnregisterConsoleIME
, // Not present in Win7
102 // ConsolepQueryConsoleIME, // Added only in Vista and Win2k8, not present in Win7
104 ConsolepAttach
, // Not present in Win7
105 ConsolepGetSelectionInfo
,
106 ConsolepGetProcessList
,
108 ConsolepGetHistory
, // Added in Vista+
109 ConsolepSetHistory
, // Added in Vista+
110 // ConsolepSetCurrentFont, // Added in Vista+
111 // ConsolepSetScreenBufferInfo, // Added in Vista+
112 // ConsolepClientConnect, // Added in Win7
115 } CONSRV_API_NUMBER
, *PCONSRV_API_NUMBER
;
118 // See http://msdn.microsoft.com/en-us/library/windows/desktop/bb773359(v=vs.85).aspx
120 typedef struct _CONSOLE_PROPERTIES
123 WORD wPopupFillAttribute
;
126 // Not on MSDN, but show up in binary
131 COORD dwScreenBufferSize
;
133 COORD dwWindowOrigin
;
135 DWORD nInputBufferSize
;
139 WCHAR FaceName
[LF_FACESIZE
];
145 UINT uHistoryBufferSize
;
146 UINT uNumberOfHistoryBuffers
;
148 COLORREF ColorTable
[16];
150 //NT_FE_CONSOLE_PROPS
152 } CONSOLE_PROPERTIES
;
155 // To minimize code changes, some fields were put here even though they really only belong in
156 // CONSRV_API_CONNECTINFO. Do not change the ordering however, as it's required for Windows
159 typedef struct _CONSOLE_START_INFO
165 DWORD dwStartupFlags
;
167 BOOLEAN ConsoleNeeded
; // Used for GUI apps only.
168 LPTHREAD_START_ROUTINE CtrlDispatcher
;
169 LPTHREAD_START_ROUTINE ImeDispatcher
;
170 LPTHREAD_START_ROUTINE PropDispatcher
;
172 WCHAR ConsoleTitle
[MAX_PATH
+ 1]; // Console title or full path to the startup shortcut
176 WCHAR AppPath
[128]; // Full path of the launched app
177 ULONG IconPathLength
;
178 WCHAR IconPath
[MAX_PATH
+ 1]; // Path to the file containing the icon
179 } CONSOLE_START_INFO
, *PCONSOLE_START_INFO
;
181 typedef struct _CONSRV_API_CONNECTINFO
183 HANDLE ConsoleHandle
;
184 HANDLE InputWaitHandle
;
190 /* Adapted from CONSOLE_ALLOCCONSOLE */
191 CONSOLE_START_INFO ConsoleStartInfo
;
192 } CONSRV_API_CONNECTINFO
, *PCONSRV_API_CONNECTINFO
;
195 C_ASSERT(sizeof(CONSRV_API_CONNECTINFO
) == 0x638);
200 HANDLE ConsoleHandle
;
202 PDWORD ProcessIdsList
;
203 } CONSOLE_GETPROCESSLIST
, *PCONSOLE_GETPROCESSLIST
;
207 HANDLE ConsoleHandle
;
209 DWORD ProcessGroupId
;
210 } CONSOLE_GENERATECTRLEVENT
, *PCONSOLE_GENERATECTRLEVENT
;
214 HANDLE ConsoleHandle
;
215 } CONSOLE_NOTIFYLASTCLOSE
, *PCONSOLE_NOTIFYLASTCLOSE
;
224 ULONG NrCharactersToWrite
;
225 ULONG NrCharactersWritten
;
229 } CONSOLE_WRITECONSOLE
, *PCONSOLE_WRITECONSOLE
;
236 ULONG NrCharactersToRead
;
237 ULONG NrCharactersRead
;
239 UNICODE_STRING ExeName
;
240 DWORD CtrlWakeupMask
;
241 DWORD ControlKeyState
;
245 } CONSOLE_READCONSOLE
, *PCONSOLE_READCONSOLE
;
249 PCONSOLE_START_INFO ConsoleStartInfo
;
251 HANDLE ConsoleHandle
;
255 HANDLE InputWaitHandle
;
256 LPTHREAD_START_ROUTINE CtrlDispatcher
;
257 LPTHREAD_START_ROUTINE PropDispatcher
;
258 } CONSOLE_ALLOCCONSOLE
, *PCONSOLE_ALLOCCONSOLE
;
262 DWORD ProcessId
; // If ProcessId == ATTACH_PARENT_PROCESS == -1, then attach the current process to its parent process console.
263 HANDLE ConsoleHandle
;
267 HANDLE InputWaitHandle
;
268 LPTHREAD_START_ROUTINE CtrlDispatcher
;
269 LPTHREAD_START_ROUTINE PropDispatcher
;
270 } CONSOLE_ATTACHCONSOLE
, *PCONSOLE_ATTACHCONSOLE
;
275 } CONSOLE_FREECONSOLE
, *PCONSOLE_FREECONSOLE
;
279 HANDLE ConsoleHandle
;
281 COORD ScreenBufferSize
;
282 COORD CursorPosition
;
286 COORD MaximumViewSize
;
287 } CONSOLE_GETSCREENBUFFERINFO
, *PCONSOLE_GETSCREENBUFFERINFO
;
291 HANDLE ConsoleHandle
;
294 } CONSOLE_SETCURSORPOSITION
, *PCONSOLE_SETCURSORPOSITION
;
298 HANDLE ConsoleHandle
;
302 } CONSOLE_SHOWCURSOR
, *PCONSOLE_SHOWCURSOR
;
306 HANDLE ConsoleHandle
;
308 HCURSOR CursorHandle
;
309 } CONSOLE_SETCURSOR
, *PCONSOLE_SETCURSOR
;
313 HANDLE ConsoleHandle
;
315 CONSOLE_CURSOR_INFO Info
;
320 } CONSOLE_GETSETCURSORINFO
, *PCONSOLE_GETSETCURSORINFO
;
324 HANDLE ConsoleHandle
;
326 } CONSOLE_GETMOUSEINFO
, *PCONSOLE_GETMOUSEINFO
;
330 HANDLE ConsoleHandle
;
333 } CONSOLE_SETTEXTATTRIB
, *PCONSOLE_SETTEXTATTRIB
;
337 HANDLE ConsoleHandle
;
340 } CONSOLE_GETSETCONSOLEMODE
, *PCONSOLE_GETSETCONSOLEMODE
;
344 HANDLE ConsoleHandle
;
345 DWORD DisplayMode
; // ModeFlags
346 } CONSOLE_GETDISPLAYMODE
, *PCONSOLE_GETDISPLAYMODE
;
350 HANDLE ConsoleHandle
;
352 DWORD DisplayMode
; // ModeFlags
355 } CONSOLE_SETDISPLAYMODE
, *PCONSOLE_SETDISPLAYMODE
;
358 * Console hardware states.
360 #define CONSOLE_HARDWARE_STATE_GDI_MANAGED 0
361 #define CONSOLE_HARDWARE_STATE_DIRECT 1
365 HANDLE ConsoleHandle
;
369 } CONSOLE_GETSETHWSTATE
, *PCONSOLE_GETSETHWSTATE
;
375 HANDLE ConsoleHandle
;
379 /* Type of the screen buffer: CONSOLE_TEXTMODE_BUFFER or CONSOLE_GRAPHICS_BUFFER */
380 DWORD ScreenBufferType
;
382 * This structure holds the initialization information
383 * for graphics screen buffers.
385 CONSOLE_GRAPHICS_BUFFER_INFO GraphicsBufferInfo
;
388 HANDLE OutputHandle
; /* Handle to newly created screen buffer */
389 } CONSOLE_CREATESCREENBUFFER
, *PCONSOLE_CREATESCREENBUFFER
;
393 HANDLE ConsoleHandle
;
394 HANDLE OutputHandle
; /* Handle to screen buffer to switch to */
395 } CONSOLE_SETACTIVESCREENBUFFER
, *PCONSOLE_SETACTIVESCREENBUFFER
;
399 HANDLE ConsoleHandle
;
402 } CONSOLE_INVALIDATEDIBITS
, *PCONSOLE_INVALIDATEDIBITS
;
406 HANDLE ConsoleHandle
;
408 HPALETTE PaletteHandle
;
410 } CONSOLE_SETPALETTE
, *PCONSOLE_SETPALETTE
;
414 HANDLE ConsoleHandle
;
418 } CONSOLE_GETSETCONSOLETITLE
, *PCONSOLE_GETSETCONSOLETITLE
;
427 SMALL_RECT WriteRegion
;
429 } CONSOLE_WRITEOUTPUT
, *PCONSOLE_WRITEOUTPUT
;
433 HANDLE ConsoleHandle
;
435 } CONSOLE_FLUSHINPUTBUFFER
, *PCONSOLE_FLUSHINPUTBUFFER
;
439 HANDLE ConsoleHandle
;
441 SMALL_RECT ScrollRectangle
;
442 SMALL_RECT ClipRectangle
;
443 BOOL UseClipRectangle
;
444 COORD DestinationOrigin
;
447 } CONSOLE_SCROLLSCREENBUFFER
, *PCONSOLE_SCROLLSCREENBUFFER
;
451 * An attribute or a character are instances of the same entity, namely
452 * a "code" (what would be called an (ANSI) escape sequence). Therefore
453 * encode them inside the same structure.
455 typedef enum _CODE_TYPE
459 CODE_ATTRIBUTE
= 0x03
466 DWORD NumCodesToRead
;
479 } pCode
; // Either a pointer to a character or to an attribute.
480 } CONSOLE_READOUTPUTCODE
, *PCONSOLE_READOUTPUTCODE
;
486 ULONG BufferSize
; // Seems unusued
491 ULONG NrCharactersWritten
; // Seems unusued
500 } pCode
; // Either a pointer to a character or to an attribute.
501 } CONSOLE_WRITEOUTPUTCODE
, *PCONSOLE_WRITEOUTPUTCODE
;
513 } Code
; // Either a character or an attribute.
518 ULONG NrCharactersWritten
; // FIXME: Only for chars, is it removable ?
519 } CONSOLE_FILLOUTPUTCODE
, *PCONSOLE_FILLOUTPUTCODE
;
525 PINPUT_RECORD InputRecord
;
529 } CONSOLE_GETINPUT
, *PCONSOLE_GETINPUT
;
538 SMALL_RECT ReadRegion
;
540 } CONSOLE_READOUTPUT
, *PCONSOLE_READOUTPUT
;
546 INPUT_RECORD
* InputRecord
;
549 } CONSOLE_WRITEINPUT
, *PCONSOLE_WRITEINPUT
;
553 HANDLE ConsoleHandle
;
555 DWORD NumberOfEvents
;
556 } CONSOLE_GETNUMINPUTEVENTS
, *PCONSOLE_GETNUMINPUTEVENTS
;
562 HANDLE ConsoleHandle
;
564 } CONSOLE_CLOSEHANDLE
, *PCONSOLE_CLOSEHANDLE
;
569 HANDLE ConsoleHandle
;
571 } CONSOLE_VERIFYHANDLE
, *PCONSOLE_VERIFYHANDLE
;
575 HANDLE ConsoleHandle
;
578 BOOLEAN InheritHandle
;
581 } CONSOLE_DUPLICATEHANDLE
, *PCONSOLE_DUPLICATEHANDLE
;
585 HANDLE ConsoleHandle
;
588 } CONSOLE_GETHANDLEINFO
, *PCONSOLE_GETHANDLEINFO
;
592 HANDLE ConsoleHandle
;
596 } CONSOLE_SETHANDLEINFO
, *PCONSOLE_SETHANDLEINFO
;
601 typedef enum _CONSOLE_HANDLE_TYPE
605 } CONSOLE_HANDLE_TYPE
;
609 HANDLE ConsoleHandle
;
610 CONSOLE_HANDLE_TYPE HandleType
;
615 } CONSOLE_OPENCONSOLE
, *PCONSOLE_OPENCONSOLE
;
621 HANDLE ConsoleHandle
;
624 } CONSOLE_GETLARGESTWINDOWSIZE
, *PCONSOLE_GETLARGESTWINDOWSIZE
;
628 HANDLE ConsoleHandle
;
633 } CONSOLE_MENUCONTROL
, *PCONSOLE_MENUCONTROL
;
637 HANDLE ConsoleHandle
;
639 } CONSOLE_SETMENUCLOSE
, *PCONSOLE_SETMENUCLOSE
;
643 HANDLE ConsoleHandle
;
646 SMALL_RECT WindowRect
; // New console window position in the screen-buffer frame (Absolute == TRUE)
647 // or in the old window position frame (Absolute == FALSE).
648 } CONSOLE_SETWINDOWINFO
, *PCONSOLE_SETWINDOWINFO
;
652 HANDLE ConsoleHandle
;
654 } CONSOLE_GETWINDOW
, *PCONSOLE_GETWINDOW
;
658 HANDLE ConsoleHandle
;
660 } CONSOLE_SETICON
, *PCONSOLE_SETICON
;
666 HANDLE ConsoleHandle
;
668 USHORT TargetLength
; // Also used for storing the number of bytes written.
675 } CONSOLE_ADDGETALIAS
, *PCONSOLE_ADDGETALIAS
;
679 HANDLE ConsoleHandle
;
684 ULONG AliasesBufferLength
;
686 } CONSOLE_GETALLALIASES
, *PCONSOLE_GETALLALIASES
;
690 HANDLE ConsoleHandle
;
696 } CONSOLE_GETALLALIASESLENGTH
, *PCONSOLE_GETALLALIASESLENGTH
;
700 HANDLE ConsoleHandle
;
701 ULONG Length
; // ExeLength; // ExesLength
704 } CONSOLE_GETALIASESEXES
, *PCONSOLE_GETALIASESEXES
;
708 HANDLE ConsoleHandle
;
711 } CONSOLE_GETALIASESEXESLENGTH
, *PCONSOLE_GETALIASESEXESLENGTH
;
717 HANDLE ConsoleHandle
;
724 } CONSOLE_GETCOMMANDHISTORY
, *PCONSOLE_GETCOMMANDHISTORY
;
728 HANDLE ConsoleHandle
;
734 } CONSOLE_GETCOMMANDHISTORYLENGTH
, *PCONSOLE_GETCOMMANDHISTORYLENGTH
;
738 HANDLE ConsoleHandle
;
743 } CONSOLE_EXPUNGECOMMANDHISTORY
, *PCONSOLE_EXPUNGECOMMANDHISTORY
;
747 UINT HistoryBufferSize
;
748 UINT NumberOfHistoryBuffers
;
750 } CONSOLE_GETSETHISTORYINFO
, *PCONSOLE_GETSETHISTORYINFO
;
754 HANDLE ConsoleHandle
;
760 } CONSOLE_SETHISTORYNUMBERCOMMANDS
, *PCONSOLE_SETHISTORYNUMBERCOMMANDS
;
764 HANDLE ConsoleHandle
;
766 } CONSOLE_SETHISTORYMODE
, *PCONSOLE_SETHISTORYMODE
;
772 HANDLE ConsoleHandle
;
775 } CONSOLE_SETSCREENBUFFERSIZE
, *PCONSOLE_SETSCREENBUFFERSIZE
;
779 HANDLE ConsoleHandle
;
780 CONSOLE_SELECTION_INFO Info
;
781 } CONSOLE_GETSELECTIONINFO
, *PCONSOLE_GETSELECTIONINFO
;
785 HANDLE ConsoleHandle
;
787 BOOL OutputCP
; // TRUE : Output Code Page ; FALSE : Input Code Page
788 } CONSOLE_GETINPUTOUTPUTCP
, *PCONSOLE_GETINPUTOUTPUTCP
;
792 HANDLE ConsoleHandle
;
794 BOOL OutputCP
; // TRUE : Output Code Page ; FALSE : Input Code Page
796 } CONSOLE_SETINPUTOUTPUTCP
, *PCONSOLE_SETINPUTOUTPUTCP
;
798 typedef struct _CONSOLE_API_MESSAGE
802 PCSR_CAPTURE_BUFFER CsrCaptureData
;
803 CSR_API_NUMBER ApiNumber
;
808 /* Console initialization and uninitialization */
809 CONSOLE_ALLOCCONSOLE AllocConsoleRequest
;
810 CONSOLE_ATTACHCONSOLE AttachConsoleRequest
;
811 CONSOLE_FREECONSOLE FreeConsoleRequest
;
814 CONSOLE_GETPROCESSLIST GetProcessListRequest
;
815 CONSOLE_GENERATECTRLEVENT GenerateCtrlEventRequest
;
816 CONSOLE_NOTIFYLASTCLOSE NotifyLastCloseRequest
;
819 CONSOLE_OPENCONSOLE OpenConsoleRequest
;
820 CONSOLE_CLOSEHANDLE CloseHandleRequest
;
821 CONSOLE_VERIFYHANDLE VerifyHandleRequest
;
822 CONSOLE_DUPLICATEHANDLE DuplicateHandleRequest
;
823 CONSOLE_GETHANDLEINFO GetHandleInfoRequest
;
824 CONSOLE_SETHANDLEINFO SetHandleInfoRequest
;
827 CONSOLE_SHOWCURSOR ShowCursorRequest
;
828 CONSOLE_SETCURSOR SetCursorRequest
;
829 CONSOLE_GETSETCURSORINFO CursorInfoRequest
;
830 CONSOLE_SETCURSORPOSITION SetCursorPositionRequest
;
831 CONSOLE_GETMOUSEINFO GetMouseInfoRequest
;
834 CONSOLE_CREATESCREENBUFFER CreateScreenBufferRequest
;
835 CONSOLE_SETACTIVESCREENBUFFER SetScreenBufferRequest
;
836 CONSOLE_GETSCREENBUFFERINFO ScreenBufferInfoRequest
;
837 CONSOLE_SETSCREENBUFFERSIZE SetScreenBufferSizeRequest
;
838 CONSOLE_SCROLLSCREENBUFFER ScrollScreenBufferRequest
;
840 CONSOLE_GETSELECTIONINFO GetSelectionInfoRequest
;
841 CONSOLE_FLUSHINPUTBUFFER FlushInputBufferRequest
;
844 CONSOLE_GETSETCONSOLEMODE ConsoleModeRequest
;
845 CONSOLE_GETDISPLAYMODE GetDisplayModeRequest
;
846 CONSOLE_SETDISPLAYMODE SetDisplayModeRequest
;
847 CONSOLE_GETSETHWSTATE HardwareStateRequest
;
850 CONSOLE_INVALIDATEDIBITS InvalidateDIBitsRequest
;
851 CONSOLE_SETPALETTE SetPaletteRequest
;
852 CONSOLE_GETSETCONSOLETITLE TitleRequest
;
853 CONSOLE_GETLARGESTWINDOWSIZE GetLargestWindowSizeRequest
;
854 CONSOLE_MENUCONTROL MenuControlRequest
;
855 CONSOLE_SETMENUCLOSE SetMenuCloseRequest
;
856 CONSOLE_SETWINDOWINFO SetWindowInfoRequest
;
857 CONSOLE_GETWINDOW GetWindowRequest
;
858 CONSOLE_SETICON SetIconRequest
;
861 CONSOLE_READCONSOLE ReadConsoleRequest
; // SrvReadConsole / ReadConsole
862 CONSOLE_GETINPUT GetInputRequest
; // SrvGetConsoleInput / PeekConsoleInput & ReadConsoleInput
863 CONSOLE_READOUTPUT ReadOutputRequest
; // SrvReadConsoleOutput / ReadConsoleOutput
864 CONSOLE_READOUTPUTCODE ReadOutputCodeRequest
; // SrvReadConsoleOutputString / ReadConsoleOutputAttribute & ReadConsoleOutputCharacter
865 CONSOLE_GETNUMINPUTEVENTS GetNumInputEventsRequest
;
868 CONSOLE_WRITECONSOLE WriteConsoleRequest
; // SrvWriteConsole / WriteConsole
869 CONSOLE_WRITEINPUT WriteInputRequest
;
870 CONSOLE_WRITEOUTPUT WriteOutputRequest
;
871 CONSOLE_WRITEOUTPUTCODE WriteOutputCodeRequest
;
873 CONSOLE_FILLOUTPUTCODE FillOutputRequest
;
874 CONSOLE_SETTEXTATTRIB SetTextAttribRequest
;
877 CONSOLE_ADDGETALIAS ConsoleAliasRequest
;
878 CONSOLE_GETALLALIASES GetAllAliasesRequest
;
879 CONSOLE_GETALLALIASESLENGTH GetAllAliasesLengthRequest
;
880 CONSOLE_GETALIASESEXES GetAliasesExesRequest
;
881 CONSOLE_GETALIASESEXESLENGTH GetAliasesExesLengthRequest
;
884 CONSOLE_GETCOMMANDHISTORY GetCommandHistoryRequest
;
885 CONSOLE_GETCOMMANDHISTORYLENGTH GetCommandHistoryLengthRequest
;
886 CONSOLE_EXPUNGECOMMANDHISTORY ExpungeCommandHistoryRequest
;
887 CONSOLE_GETSETHISTORYINFO HistoryInfoRequest
;
888 CONSOLE_SETHISTORYNUMBERCOMMANDS SetHistoryNumberCommandsRequest
;
889 CONSOLE_SETHISTORYMODE SetHistoryModeRequest
;
891 /* Input and Output Code Pages */
892 CONSOLE_GETINPUTOUTPUTCP GetConsoleCPRequest
;
893 CONSOLE_SETINPUTOUTPUTCP SetConsoleCPRequest
;
895 } CONSOLE_API_MESSAGE
, *PCONSOLE_API_MESSAGE
;
897 // Check that a CONSOLE_API_MESSAGE can hold in a CSR_API_MESSAGE.
898 CHECK_API_MSG_SIZE(CONSOLE_API_MESSAGE
);