nativefont.c 3.49 KB
Newer Older
1 2 3
/*
 * Native Font control
 *
4
 * Copyright 1998, 1999 Eric Kohl
5
 *
6 7 8 9 10 11 12 13 14 15 16 17
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * 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
19
 *
20 21 22 23 24 25 26 27 28 29
 * NOTES
 *   This is just a dummy control. An author is needed! Any volunteers?
 *   I will only improve this control once in a while.
 *     Eric <ekohl@abo.rhein-zeitung.de>
 *
 * TODO:
 *   - All messages.
 *   - All notifications.
 */

30
#include <stdarg.h>
31

32
#include "windef.h"
33
#include "winbase.h"
34 35
#include "wingdi.h"
#include "winuser.h"
36
#include "commctrl.h"
37
#include "comctl32.h"
38
#include "wine/debug.h"
39

40
WINE_DEFAULT_DEBUG_CHANNEL(nativefont);
41

42 43
typedef struct
{
44
    HWND     hwndSelf;        /* my own handle */
45
} NATIVEFONT_INFO;
46

47
#define NATIVEFONT_GetInfoPtr(hwnd) ((NATIVEFONT_INFO *)GetWindowLongPtrW (hwnd, 0))
48 49

static LRESULT
50
NATIVEFONT_Create (HWND hwnd, WPARAM wParam, LPARAM lParam)
51 52 53 54
{
    NATIVEFONT_INFO *infoPtr;

    /* allocate memory for info structure */
55
    infoPtr = (NATIVEFONT_INFO *)Alloc (sizeof(NATIVEFONT_INFO));
56
    SetWindowLongPtrW (hwnd, 0, (DWORD_PTR)infoPtr);
57 58

    /* initialize info structure */
59
    infoPtr->hwndSelf = hwnd;
60 61 62 63 64

    return 0;
}

static LRESULT
65
NATIVEFONT_Destroy (NATIVEFONT_INFO *infoPtr)
66
{
67 68
    /* free control info data */
    SetWindowLongPtrW( infoPtr->hwndSelf, 0, 0 );
69
    Free (infoPtr);
70 71 72 73

    return 0;
}

74
static LRESULT WINAPI
75
NATIVEFONT_WindowProc (HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
76
{
77 78 79 80 81 82 83
    NATIVEFONT_INFO *infoPtr = NATIVEFONT_GetInfoPtr(hwnd);

    TRACE("hwnd=%p msg=%04x wparam=%08x lparam=%08lx\n",
	  hwnd, uMsg, wParam, lParam);

    if (!infoPtr && (uMsg != WM_CREATE))
	return DefWindowProcW( hwnd, uMsg, wParam, lParam );
84

85 86 87
    switch (uMsg)
    {
	case WM_CREATE:
88
	    return NATIVEFONT_Create (hwnd, wParam, lParam);
89 90

	case WM_DESTROY:
91
	    return NATIVEFONT_Destroy (infoPtr);
92

93 94 95 96 97 98 99 100
        case WM_MOVE:
        case WM_SIZE:
        case WM_SHOWWINDOW:
        case WM_WINDOWPOSCHANGING:
        case WM_WINDOWPOSCHANGED:
        case WM_SETFONT:
        case WM_GETDLGCODE:
	    /* FIXME("message %04x seen but stubbed\n", uMsg); */
101
	    return DefWindowProcW (hwnd, uMsg, wParam, lParam);
102

103
	default:
104 105
	    if ((uMsg >= WM_USER) && (uMsg < WM_APP))
		ERR("unknown msg %04x wp=%08x lp=%08lx\n",
106
		     uMsg, wParam, lParam);
107
	    return DefWindowProcW (hwnd, uMsg, wParam, lParam);
108 109 110 111 112
    }
}


VOID
113
NATIVEFONT_Register (void)
114
{
115
    WNDCLASSW wndClass;
116

117
    ZeroMemory (&wndClass, sizeof(WNDCLASSW));
118
    wndClass.style         = CS_GLOBALCLASS;
119
    wndClass.lpfnWndProc   = NATIVEFONT_WindowProc;
120 121
    wndClass.cbClsExtra    = 0;
    wndClass.cbWndExtra    = sizeof(NATIVEFONT_INFO *);
122 123 124
    wndClass.hCursor       = LoadCursorW (0, (LPWSTR)IDC_ARROW);
    wndClass.hbrBackground = (HBRUSH)(COLOR_BTNFACE + 1);
    wndClass.lpszClassName = WC_NATIVEFONTCTLW;
125

126
    RegisterClassW (&wndClass);
127 128 129 130
}


VOID
131
NATIVEFONT_Unregister (void)
132
{
133
    UnregisterClassW (WC_NATIVEFONTCTLW, NULL);
134
}