Last updated: 18. 1.1998, 16:11
<* +M2EXTENSIONS *> MODULE About1; (*-------------------------------------------- ABOUT1.C --- About Box Demo Program No. 3 (c) Charles Petzold, 1996 About1.MOD --- Translation to XDS Modula-2 (c) Peter Stadler, 1997 ------------------------------------------*) IMPORT h2d_about1; IMPORT Windows; IMPORT SYSTEM; CONST szAppName = "About1"; VAR msg : Windows.MSG; hwnd : Windows.HWND; wc : Windows.WNDCLASSEX; hInstance : Windows.HINSTANCE; (*++++*****************************************************************) PROCEDURE [Windows.CALLBACK] AboutDlgProc (hDlg : Windows.HWND; (**********************************************************************) iMsg : Windows.UINT; wParam : Windows.WPARAM; lParam : Windows.LPARAM) : Windows.BOOL; BEGIN CASE (iMsg) OF | Windows.WM_INITDIALOG : RETURN TRUE; | Windows.WM_COMMAND : CASE (Windows.LOWORD (wParam)) OF | Windows.IDOK : Windows.EndDialog (hDlg, 0); RETURN TRUE; | Windows.IDCANCEL : Windows.EndDialog (hDlg, 0); RETURN TRUE; ELSE RETURN FALSE; END; ELSE RETURN FALSE; END; END AboutDlgProc; (*++++*****************************************************************) PROCEDURE [Windows.CALLBACK] WndProc (hwnd : Windows.HWND; (**********************************************************************) iMsg : Windows.UINT; wParam : Windows.WPARAM; lParam : Windows.LPARAM) : Windows.LRESULT; BEGIN CASE (iMsg) OF | Windows.WM_CREATE : (* hInstance := ((PCREATESTRUCT) lParam)^.hInstance; *) hInstance := Windows.MyInstance(); RETURN 0; | Windows.WM_COMMAND : CASE (Windows.LOWORD (wParam)) OF | h2d_about1.IDM_ABOUT : Windows.DialogBox (hInstance, "AboutBox", hwnd, AboutDlgProc); RETURN 0; ELSE RETURN 0; END; | Windows.WM_DESTROY : Windows.PostQuitMessage (0); RETURN 0; ELSE RETURN Windows.DefWindowProc (hwnd, iMsg, wParam, lParam); END; END WndProc; (*++++*****************************************************************) PROCEDURE InitApplication () : BOOLEAN; (**********************************************************************) VAR rc : CARDINAL; BEGIN wc.cbSize := SIZE(wc); wc.style := Windows.CS_HREDRAW + Windows.CS_VREDRAW; wc.lpfnWndProc := WndProc; wc.cbClsExtra := 0; wc.cbWndExtra := 0; wc.hInstance := Windows.MyInstance(); wc.hIcon := Windows.LoadIcon (wc.hInstance,szAppName); wc.hCursor := Windows.LoadCursor (NIL, Windows.IDC_ARROW); wc.hbrBackground := SYSTEM.CAST(Windows.HBRUSH,Windows.GetStockObject(Windows.WHITE_BRUSH)); wc.lpszMenuName := SYSTEM.ADR(szAppName); wc.lpszClassName := SYSTEM.ADR(szAppName); wc.hIconSm := Windows.LoadIcon (wc.hInstance,szAppName); rc := Windows.RegisterClassEx(wc); RETURN rc#0; END InitApplication; (*++++*****************************************************************) PROCEDURE InitMainWindow () : BOOLEAN; (**********************************************************************) BEGIN hwnd := Windows.CreateWindow (szAppName, "About Box Demo Program #1: Translation to XDS Modula-2", Windows.WS_OVERLAPPEDWINDOW, Windows.CW_USEDEFAULT, Windows.CW_USEDEFAULT, Windows.CW_USEDEFAULT, Windows.CW_USEDEFAULT, NIL, NIL, Windows.MyInstance(), NIL); IF hwnd = NIL THEN RETURN FALSE; END; Windows.ShowWindow (hwnd, Windows.SW_SHOWDEFAULT); Windows.UpdateWindow (hwnd); RETURN TRUE; END InitMainWindow; BEGIN IF InitApplication() AND InitMainWindow() THEN WHILE (Windows.GetMessage(msg,NIL,0,0)) DO Windows.TranslateMessage(msg); Windows.DispatchMessage(msg); END; END; END About1.