2 * an application for displaying Win32 console
4 * Copyright 2001 Eric Pouech
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
26 #include "wineconsole_res.h"
28 /* this is the configuration stored & loaded into the registry */
30 unsigned cell_width; /* width in pixels of a character */
31 unsigned cell_height; /* height in pixels of a character */
32 int cursor_size; /* in % of cell height */
35 WCHAR face_name[32]; /* name of font (size is LF_FACESIZE) */
37 DWORD history_size; /* number of commands in history buffer */
38 DWORD history_nodup; /* TRUE if commands are not stored twice in buffer */
39 DWORD menu_mask; /* MK_CONTROL MK_SHIFT mask to drive submenu opening */
40 DWORD quick_edit; /* whether mouse ops are sent to app (false) or used for content selection (true) */
41 unsigned sb_width; /* active screen buffer width */
42 unsigned sb_height; /* active screen buffer height */
43 unsigned win_width; /* size (in cells) of visible part of window (width & height) */
45 COORD win_pos; /* position (in cells) of visible part of screen buffer in window */
46 BOOL exit_on_die; /* whether the wineconsole should quit if server destroys the console */
47 unsigned edition_mode; /* edition mode flavor while line editing */
48 WCHAR* registry; /* <x> part of HKLU\\<x>\\Console where config is read from (NULL if default settings) */
52 struct config_data curcfg;
54 CHAR_INFO* cells; /* local copy of cells (sb_width * sb_height) */
56 COORD cursor; /* position in cells of cursor */
58 HANDLE hConIn; /* console input handle */
59 HANDLE hConOut; /* screen buffer handle: has to be changed when active sb changes */
60 HANDLE hSynchro; /* waitable handle signalled by server when something in server has been modified */
61 INT nCmdShow; /* argument of WinMain */
63 int (*fnMainLoop)(struct inner_data* data);
64 void (*fnPosCursor)(const struct inner_data* data);
65 void (*fnShapeCursor)(struct inner_data* data, int size, int vis, BOOL force);
66 void (*fnComputePositions)(struct inner_data* data);
67 void (*fnRefresh)(const struct inner_data* data, int tp, int bm);
68 void (*fnResizeScreenBuffer)(struct inner_data* data);
69 void (*fnSetTitle)(const struct inner_data* data);
70 void (*fnScroll)(struct inner_data* data, int pos, BOOL horz);
71 void (*fnSetFont)(struct inner_data* data, const WCHAR* font, unsigned height, unsigned weight);
72 void (*fnDeleteBackend)(struct inner_data* data);
74 void* private; /* data part belonging to the choosen backed */
77 /* from wineconsole.c */
78 extern void WINECON_Fatal(const char* msg);
79 extern void WINECON_NotifyWindowChange(struct inner_data* data);
80 extern int WINECON_GetHistorySize(HANDLE hConIn);
81 extern BOOL WINECON_SetHistorySize(HANDLE hConIn, int size);
82 extern int WINECON_GetHistoryMode(HANDLE hConIn);
83 extern BOOL WINECON_SetHistoryMode(HANDLE hConIn, int mode);
84 extern BOOL WINECON_GetConsoleTitle(HANDLE hConIn, WCHAR* buffer, size_t len);
85 extern void WINECON_FetchCells(struct inner_data* data, int upd_tp, int upd_bm);
86 extern int WINECON_GrabChanges(struct inner_data* data);
87 extern VOID WINECON_SetConfig(struct inner_data* data,
88 const struct config_data* cfg);
90 extern void WINECON_RegLoad(const WCHAR* appname, struct config_data* cfg);
91 extern void WINECON_RegSave(const struct config_data* cfg);
92 extern void WINECON_DumpConfig(const char* pfx, const struct config_data* cfg);
96 init_success, init_failed, init_not_supported
98 extern enum init_return WCUSER_InitBackend(struct inner_data* data);
99 extern enum init_return WCCURSES_InitBackend(struct inner_data* data);