Commit e53cd36e authored by Eric Pouech's avatar Eric Pouech Committed by Alexandre Julliard

Removed Trace macro and replaced it by Wine debug channel facility.

Made the font lookup at startup more robust and now save registry at startup time if a new font is chosen (as spotted by Sylvain Petreolle). Fixed an update bug spotted by Jason Edmeades.
parent 736e81c6
...@@ -23,6 +23,10 @@ ...@@ -23,6 +23,10 @@
#include "prsht.h" #include "prsht.h"
#include "winecon_user.h" #include "winecon_user.h"
#include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL(wineconsole);
enum WCUSER_ApplyTo { enum WCUSER_ApplyTo {
/* Prop sheet CFG */ /* Prop sheet CFG */
WCUSER_ApplyToCursorSize, WCUSER_ApplyToCursorSize,
...@@ -392,6 +396,7 @@ static int CALLBACK font_enum_size2(const LOGFONT* lf, const TEXTMETRIC* tm, ...@@ -392,6 +396,7 @@ static int CALLBACK font_enum_size2(const LOGFONT* lf, const TEXTMETRIC* tm,
{ {
struct dialog_info* di = (struct dialog_info*)lParam; struct dialog_info* di = (struct dialog_info*)lParam;
WCUSER_DumpTextMetric(tm, FontType);
if (WCUSER_ValidateFontMetric(di->data, tm, FontType)) if (WCUSER_ValidateFontMetric(di->data, tm, FontType))
{ {
di->nFont++; di->nFont++;
...@@ -406,6 +411,7 @@ static int CALLBACK font_enum(const LOGFONT* lf, const TEXTMETRIC* tm, ...@@ -406,6 +411,7 @@ static int CALLBACK font_enum(const LOGFONT* lf, const TEXTMETRIC* tm,
struct dialog_info* di = (struct dialog_info*)lParam; struct dialog_info* di = (struct dialog_info*)lParam;
HDC hdc; HDC hdc;
WCUSER_DumpLogFont("font", lf, FontType);
if (WCUSER_ValidateFont(di->data, lf) && (hdc = GetDC(di->hDlg))) if (WCUSER_ValidateFont(di->data, lf) && (hdc = GetDC(di->hDlg)))
{ {
if (FontType & RASTER_FONTTYPE) if (FontType & RASTER_FONTTYPE)
...@@ -439,6 +445,7 @@ static int CALLBACK font_enum_size(const LOGFONT* lf, const TEXTMETRIC* tm, ...@@ -439,6 +445,7 @@ static int CALLBACK font_enum_size(const LOGFONT* lf, const TEXTMETRIC* tm,
WCHAR buf[32]; WCHAR buf[32];
static const WCHAR fmt[] = {'%','l','d',0}; static const WCHAR fmt[] = {'%','l','d',0};
WCUSER_DumpTextMetric(tm, FontType);
if (di->nFont == 0 && !(FontType & RASTER_FONTTYPE)) if (di->nFont == 0 && !(FontType & RASTER_FONTTYPE))
{ {
static const int sizes[] = {8,9,10,11,12,14,16,18,20,22,24,26,28,36,48,72}; static const int sizes[] = {8,9,10,11,12,14,16,18,20,22,24,26,28,36,48,72};
...@@ -523,8 +530,8 @@ static BOOL select_font(struct dialog_info* di) ...@@ -523,8 +530,8 @@ static BOOL select_font(struct dialog_info* di)
if (!hFont) return FALSE; if (!hFont) return FALSE;
if (config.cell_height != di->font[size_idx].height) if (config.cell_height != di->font[size_idx].height)
Trace(0, "select_font: mismatched heights (%u<>%u)\n", WINE_TRACE("select_font: mismatched heights (%u<>%u)\n",
config.cell_height, di->font[size_idx].height); config.cell_height, di->font[size_idx].height);
hOldFont = (HFONT)SendDlgItemMessage(di->hDlg, IDC_FNT_PREVIEW, WM_GETFONT, 0L, 0L); hOldFont = (HFONT)SendDlgItemMessage(di->hDlg, IDC_FNT_PREVIEW, WM_GETFONT, 0L, 0L);
SendDlgItemMessage(di->hDlg, IDC_FNT_PREVIEW, WM_SETFONT, (DWORD)hFont, TRUE); SendDlgItemMessage(di->hDlg, IDC_FNT_PREVIEW, WM_SETFONT, (DWORD)hFont, TRUE);
...@@ -575,7 +582,7 @@ static BOOL fill_list_size(struct dialog_info* di, BOOL doInit) ...@@ -575,7 +582,7 @@ static BOOL fill_list_size(struct dialog_info* di, BOOL doInit)
di->font[idx].weight == di->config->font_weight) di->font[idx].weight == di->config->font_weight)
{ {
if (ref == -1) ref = idx; if (ref == -1) ref = idx;
else Trace(0, "Several matches found: ref=%d idx=%d\n", ref, idx); else WINE_TRACE("Several matches found: ref=%d idx=%d\n", ref, idx);
} }
} }
idx = (ref == -1) ? 0 : ref; idx = (ref == -1) ? 0 : ref;
......
...@@ -23,6 +23,10 @@ ...@@ -23,6 +23,10 @@
#include "winreg.h" #include "winreg.h"
#include "winecon_private.h" #include "winecon_private.h"
#include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL(wineconsole);
static const WCHAR wszConsole[] = {'C','o','n','s','o','l','e',0}; static const WCHAR wszConsole[] = {'C','o','n','s','o','l','e',0};
static const WCHAR wszCursorSize[] = {'C','u','r','s','o','r','S','i','z','e',0}; static const WCHAR wszCursorSize[] = {'C','u','r','s','o','r','S','i','z','e',0};
static const WCHAR wszCursorVisible[] = {'C','u','r','s','o','r','V','i','s','i','b','l','e',0}; static const WCHAR wszCursorVisible[] = {'C','u','r','s','o','r','V','i','s','i','b','l','e',0};
...@@ -125,7 +129,7 @@ BOOL WINECON_RegSave(const struct config_data* cfg) ...@@ -125,7 +129,7 @@ BOOL WINECON_RegSave(const struct config_data* cfg)
if (RegCreateKey(HKEY_CURRENT_USER, wszConsole, &hConKey)) if (RegCreateKey(HKEY_CURRENT_USER, wszConsole, &hConKey))
{ {
Trace(0, "Can't open registry for saving\n"); WINE_ERR("Can't open registry for saving\n");
return FALSE; return FALSE;
} }
......
...@@ -67,19 +67,6 @@ struct inner_data { ...@@ -67,19 +67,6 @@ struct inner_data {
void* private; /* data part belonging to the choosen backed */ void* private; /* data part belonging to the choosen backed */
}; };
# ifdef __GNUC__
extern void XTracer(int level, const char* format, ...) __attribute__((format (printf,2,3)));
# else
extern void XTracer(int level, const char* format, ...);
# endif
#if 0
/* Trace mode */
# define Trace XTracer
#else
/* non trace mode */
# define Trace (1) ? (void)0 : XTracer
#endif
/* from wineconsole.c */ /* from wineconsole.c */
extern void WINECON_NotifyWindowChange(struct inner_data* data); extern void WINECON_NotifyWindowChange(struct inner_data* data);
extern int WINECON_GetHistorySize(HANDLE hConIn); extern int WINECON_GetHistorySize(HANDLE hConIn);
......
...@@ -53,3 +53,5 @@ extern HFONT WCUSER_CopyFont(struct config_data* config, HWND hWnd, const LOGFON ...@@ -53,3 +53,5 @@ extern HFONT WCUSER_CopyFont(struct config_data* config, HWND hWnd, const LOGFON
extern void WCUSER_FillLogFont(LOGFONT* lf, const WCHAR* name, extern void WCUSER_FillLogFont(LOGFONT* lf, const WCHAR* name,
UINT height, UINT weight); UINT height, UINT weight);
extern void WCUSER_DumpLogFont(const char* pfx, const LOGFONT* lf, DWORD ft);
extern void WCUSER_DumpTextMetric(const TEXTMETRIC* tm, DWORD ft);
...@@ -26,27 +26,9 @@ ...@@ -26,27 +26,9 @@
#include "wine/unicode.h" #include "wine/unicode.h"
#include "winecon_private.h" #include "winecon_private.h"
static int trace_level = 1; #include "wine/debug.h"
void XTracer(int level, const char* format, ...)
{
char buf[1024];
va_list valist;
int len;
if (level > trace_level) return;
va_start(valist, format); WINE_DEFAULT_DEBUG_CHANNEL(wineconsole);
len = vsnprintf(buf, sizeof(buf), format, valist);
va_end(valist);
if ((len <= -1) || (len >= sizeof(buf)))
{
len = sizeof(buf) - 1;
buf[len] = 0;
buf[len - 1] = buf[len - 2] = buf[len - 3] = '.';
}
fprintf(stderr, buf);
}
/****************************************************************** /******************************************************************
* WINECON_FetchCells * WINECON_FetchCells
...@@ -211,7 +193,7 @@ int WINECON_GrabChanges(struct inner_data* data) ...@@ -211,7 +193,7 @@ int WINECON_GrabChanges(struct inner_data* data)
else num = 0; else num = 0;
} }
SERVER_END_REQ; SERVER_END_REQ;
if (!num) {Trace(0, "hmm renderer signaled but no events available\n"); return 1;} if (!num) {WINE_WARN("hmm renderer signaled but no events available\n"); return 1;}
/* FIXME: should do some event compression here (cursor pos, update) */ /* FIXME: should do some event compression here (cursor pos, update) */
/* step 1: keep only last cursor pos event */ /* step 1: keep only last cursor pos event */
...@@ -251,7 +233,7 @@ int WINECON_GrabChanges(struct inner_data* data) ...@@ -251,7 +233,7 @@ int WINECON_GrabChanges(struct inner_data* data)
} }
} }
Trace(1, "Change notification:"); WINE_TRACE("Events:");
for (i = 0; i < num; i++) for (i = 0; i < num; i++)
{ {
switch (evts[i].event) switch (evts[i].event)
...@@ -269,7 +251,8 @@ int WINECON_GrabChanges(struct inner_data* data) ...@@ -269,7 +251,8 @@ int WINECON_GrabChanges(struct inner_data* data)
h = wine_server_call_err( req ) ? 0 : (HANDLE)reply->handle; h = wine_server_call_err( req ) ? 0 : (HANDLE)reply->handle;
} }
SERVER_END_REQ; SERVER_END_REQ;
Trace(1, " active(%d)", (int)h); if (WINE_TRACE_ON(wineconsole))
WINE_DPRINTF(" active(%d)", (int)h);
if (h) if (h)
{ {
CloseHandle(data->hConOut); CloseHandle(data->hConOut);
...@@ -280,19 +263,21 @@ int WINECON_GrabChanges(struct inner_data* data) ...@@ -280,19 +263,21 @@ int WINECON_GrabChanges(struct inner_data* data)
if (data->curcfg.sb_width != evts[i].u.resize.width || if (data->curcfg.sb_width != evts[i].u.resize.width ||
data->curcfg.sb_height != evts[i].u.resize.height) data->curcfg.sb_height != evts[i].u.resize.height)
{ {
Trace(1, " resize(%d,%d)", evts[i].u.resize.width, evts[i].u.resize.height); if (WINE_TRACE_ON(wineconsole))
WINE_DPRINTF(" resize(%d,%d)", evts[i].u.resize.width, evts[i].u.resize.height);
data->curcfg.sb_width = evts[i].u.resize.width; data->curcfg.sb_width = evts[i].u.resize.width;
data->curcfg.sb_height = evts[i].u.resize.height; data->curcfg.sb_height = evts[i].u.resize.height;
data->cells = HeapReAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, data->cells, data->cells = HeapReAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, data->cells,
data->curcfg.sb_width * data->curcfg.sb_height * sizeof(CHAR_INFO)); data->curcfg.sb_width * data->curcfg.sb_height * sizeof(CHAR_INFO));
if (!data->cells) {Trace(0, "OOM\n"); exit(0);} if (!data->cells) {WINE_ERR("OOM\n"); exit(0);}
data->fnResizeScreenBuffer(data); data->fnResizeScreenBuffer(data);
data->fnComputePositions(data); data->fnComputePositions(data);
} }
break; break;
case CONSOLE_RENDERER_UPDATE_EVENT: case CONSOLE_RENDERER_UPDATE_EVENT:
Trace(1, " update(%d,%d)", evts[i].u.update.top, evts[i].u.update.bottom); if (WINE_TRACE_ON(wineconsole))
WINE_DPRINTF(" update(%d,%d)", evts[i].u.update.top, evts[i].u.update.bottom);
WINECON_FetchCells(data, evts[i].u.update.top, evts[i].u.update.bottom); WINECON_FetchCells(data, evts[i].u.update.top, evts[i].u.update.bottom);
break; break;
case CONSOLE_RENDERER_CURSOR_POS_EVENT: case CONSOLE_RENDERER_CURSOR_POS_EVENT:
...@@ -301,7 +286,8 @@ int WINECON_GrabChanges(struct inner_data* data) ...@@ -301,7 +286,8 @@ int WINECON_GrabChanges(struct inner_data* data)
data->cursor.X = evts[i].u.cursor_pos.x; data->cursor.X = evts[i].u.cursor_pos.x;
data->cursor.Y = evts[i].u.cursor_pos.y; data->cursor.Y = evts[i].u.cursor_pos.y;
data->fnPosCursor(data); data->fnPosCursor(data);
Trace(1, " curs-pos(%d,%d)",evts[i].u.cursor_pos.x, evts[i].u.cursor_pos.y); if (WINE_TRACE_ON(wineconsole))
WINE_DPRINTF(" curs-pos(%d,%d)",evts[i].u.cursor_pos.x, evts[i].u.cursor_pos.y);
} }
break; break;
case CONSOLE_RENDERER_CURSOR_GEOM_EVENT: case CONSOLE_RENDERER_CURSOR_GEOM_EVENT:
...@@ -310,8 +296,9 @@ int WINECON_GrabChanges(struct inner_data* data) ...@@ -310,8 +296,9 @@ int WINECON_GrabChanges(struct inner_data* data)
{ {
data->fnShapeCursor(data, evts[i].u.cursor_geom.size, data->fnShapeCursor(data, evts[i].u.cursor_geom.size,
evts[i].u.cursor_geom.visible, FALSE); evts[i].u.cursor_geom.visible, FALSE);
Trace(1, " curs-geom(%d,%d)", if (WINE_TRACE_ON(wineconsole))
evts[i].u.cursor_geom.size, evts[i].u.cursor_geom.visible); WINE_DPRINTF(" curs-geom(%d,%d)",
evts[i].u.cursor_geom.size, evts[i].u.cursor_geom.visible);
} }
break; break;
case CONSOLE_RENDERER_DISPLAY_EVENT: case CONSOLE_RENDERER_DISPLAY_EVENT:
...@@ -319,32 +306,35 @@ int WINECON_GrabChanges(struct inner_data* data) ...@@ -319,32 +306,35 @@ int WINECON_GrabChanges(struct inner_data* data)
{ {
data->fnScroll(data, evts[i].u.display.left, TRUE); data->fnScroll(data, evts[i].u.display.left, TRUE);
data->fnPosCursor(data); data->fnPosCursor(data);
Trace(1, " h-scroll(%d)", evts[i].u.display.left); if (WINE_TRACE_ON(wineconsole))
WINE_DPRINTF(" h-scroll(%d)", evts[i].u.display.left);
} }
if (evts[i].u.display.top != data->curcfg.win_pos.Y) if (evts[i].u.display.top != data->curcfg.win_pos.Y)
{ {
data->fnScroll(data, evts[i].u.display.top, FALSE); data->fnScroll(data, evts[i].u.display.top, FALSE);
data->fnPosCursor(data); data->fnPosCursor(data);
Trace(1, " v-scroll(%d)", evts[i].u.display.top); if (WINE_TRACE_ON(wineconsole))
WINE_DPRINTF(" v-scroll(%d)", evts[i].u.display.top);
} }
if (evts[i].u.display.width != data->curcfg.win_width || if (evts[i].u.display.width != data->curcfg.win_width ||
evts[i].u.display.height != data->curcfg.win_height) evts[i].u.display.height != data->curcfg.win_height)
{ {
Trace(1, " win-size(%d,%d)", evts[i].u.display.width, evts[i].u.display.height); if (WINE_TRACE_ON(wineconsole))
WINE_DPRINTF(" win-size(%d,%d)", evts[i].u.display.width, evts[i].u.display.height);
data->curcfg.win_width = evts[i].u.display.width; data->curcfg.win_width = evts[i].u.display.width;
data->curcfg.win_height = evts[i].u.display.height; data->curcfg.win_height = evts[i].u.display.height;
data->fnComputePositions(data); data->fnComputePositions(data);
} }
break; break;
case CONSOLE_RENDERER_EXIT_EVENT: case CONSOLE_RENDERER_EXIT_EVENT:
Trace(1, ". Exit!!\n"); if (WINE_TRACE_ON(wineconsole)) WINE_DPRINTF(". Exit!!\n");
return 0; return 0;
default: default:
Trace(0, "Unknown event type (%d)\n", evts[i].event); WINE_FIXME("Unknown event type (%d)\n", evts[i].event);
} }
} }
Trace(1, ". Done\n"); if (WINE_TRACE_ON(wineconsole)) WINE_DPRINTF(".\n");
return 1; return 1;
} }
...@@ -454,7 +444,7 @@ static BOOL WINECON_Spawn(struct inner_data* data, LPCSTR lpCmdLine) ...@@ -454,7 +444,7 @@ static BOOL WINECON_Spawn(struct inner_data* data, LPCSTR lpCmdLine)
!DuplicateHandle(GetCurrentProcess(), data->hConOut, GetCurrentProcess(), !DuplicateHandle(GetCurrentProcess(), data->hConOut, GetCurrentProcess(),
&startup.hStdError, GENERIC_READ|GENERIC_WRITE, TRUE, 0)) &startup.hStdError, GENERIC_READ|GENERIC_WRITE, TRUE, 0))
{ {
Trace(0, "can't dup handles\n"); WINE_ERR("Can't dup handles\n");
/* no need to delete handles, we're exiting the programm anyway */ /* no need to delete handles, we're exiting the programm anyway */
return FALSE; return FALSE;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment