2 * Wordpad implementation
4 * Copyright 2004 by Krzysztof Foltman
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
21 #define WIN32_LEAN_AND_MEAN
22 #define _WIN32_IE 0x0400
24 #define MAX_STRING_LEN 255
39 static const WCHAR xszAppTitle
[] = {'W','i','n','e',' ','W','o','r','d','p','a','d',0};
40 static const WCHAR xszMainMenu
[] = {'M','A','I','N','M','E','N','U',0};
42 static const WCHAR wszRichEditClass
[] = {'R','I','C','H','E','D','I','T','2','0','W',0};
43 static const WCHAR wszMainWndClass
[] = {'W','O','R','D','P','A','D','T','O','P',0};
44 static const WCHAR wszAppTitle
[] = {'W','i','n','e',' ','W','o','r','d','p','a','d',0};
47 static HWND hEditorWnd
;
49 static char szFilter
[MAX_STRING_LEN
];
51 /* Load string resources */
52 static void DoLoadStrings(void)
55 char files_rtf
[] = "*.rtf";
56 char files_txt
[] = "*.txt";
57 char files_all
[] = "*.*";
58 HINSTANCE hInstance
= (HINSTANCE
)GetWindowLongPtr(hMainWnd
, GWLP_HINSTANCE
);
60 LoadString(hInstance
, STRING_RICHTEXT_FILES_RTF
, p
, MAX_STRING_LEN
);
62 lstrcpy(p
, files_rtf
);
64 LoadString(hInstance
, STRING_TEXT_FILES_TXT
, p
, MAX_STRING_LEN
);
66 lstrcpy(p
, files_txt
);
68 LoadString(hInstance
, STRING_ALL_FILES
, p
, MAX_STRING_LEN
);
70 lstrcpy(p
, files_all
);
75 static void AddButton(HWND hwndToolBar
, int nImage
, int nCommand
)
79 ZeroMemory(&button
, sizeof(button
));
80 button
.iBitmap
= nImage
;
81 button
.idCommand
= nCommand
;
82 button
.fsState
= TBSTATE_ENABLED
;
83 button
.fsStyle
= TBSTYLE_BUTTON
;
86 SendMessage(hwndToolBar
, TB_ADDBUTTONS
, 1, (LPARAM
)&button
);
89 static void AddSeparator(HWND hwndToolBar
)
93 ZeroMemory(&button
, sizeof(button
));
97 button
.fsStyle
= TBSTYLE_SEP
;
100 SendMessage(hwndToolBar
, TB_ADDBUTTONS
, 1, (LPARAM
)&button
);
103 static DWORD CALLBACK
stream_in(DWORD_PTR cookie
, LPBYTE buffer
, LONG cb
, LONG
*pcb
)
105 HANDLE hFile
= (HANDLE
)cookie
;
108 if(!ReadFile(hFile
, buffer
, cb
, &read
, 0))
116 static DWORD CALLBACK
stream_out(DWORD_PTR cookie
, LPBYTE buffer
, LONG cb
, LONG
*pcb
)
120 HANDLE hFile
= (HANDLE
)cookie
;
122 ret
= WriteFile(hFile
, buffer
, cb
, &written
, 0);
124 if(!ret
|| (cb
!= written
))
132 static WCHAR wszFileName
[MAX_PATH
];
134 static void set_caption(LPCWSTR wszNewFileName
)
136 static const WCHAR wszSeparator
[] = {' ','-',' ','\0'};
137 WCHAR wszCaption
[MAX_PATH
];
141 lstrcpyW(wszCaption
, wszNewFileName
);
142 lstrcatW(wszCaption
, wszSeparator
);
143 lstrcatW(wszCaption
, wszAppTitle
);
144 SetWindowTextW(hMainWnd
, wszCaption
);
147 SetWindowTextW(hMainWnd
, wszAppTitle
);
151 static void DoOpenFile(LPCWSTR szOpenFileName
)
156 hFile
= CreateFileW(szOpenFileName
, GENERIC_READ
, FILE_SHARE_READ
, NULL
,
157 OPEN_EXISTING
, FILE_ATTRIBUTE_NORMAL
, NULL
);
158 if (hFile
== INVALID_HANDLE_VALUE
)
161 es
.dwCookie
= (DWORD_PTR
)hFile
;
162 es
.pfnCallback
= stream_in
;
164 /* FIXME: Handle different file formats */
165 SendMessageW(hEditorWnd
, EM_STREAMIN
, SF_RTF
, (LPARAM
)&es
);
169 SetFocus(hEditorWnd
);
171 set_caption(szOpenFileName
);
173 lstrcpyW(wszFileName
, szOpenFileName
);
176 static void DialogOpenFile(void)
180 char szFile
[MAX_PATH
] = "";
181 char szDefExt
[] = "rtf";
183 ZeroMemory(&ofn
, sizeof(ofn
));
185 ofn
.lStructSize
= sizeof(ofn
);
186 ofn
.Flags
= OFN_HIDEREADONLY
| OFN_FILEMUSTEXIST
| OFN_PATHMUSTEXIST
;
187 ofn
.hwndOwner
= hMainWnd
;
188 ofn
.lpstrFilter
= szFilter
;
189 ofn
.lpstrFile
= szFile
;
190 ofn
.nMaxFile
= MAX_PATH
;
191 ofn
.lpstrDefExt
= szDefExt
;
193 if(GetOpenFileName(&ofn
))
195 WCHAR szOpenFile
[MAX_PATH
];
197 MultiByteToWideChar(CP_ACP
, 0, ofn
.lpstrFile
, MAX_PATH
, szOpenFile
, sizeof(szOpenFile
)/sizeof(szOpenFile
[0]));
199 DoOpenFile(szOpenFile
);
203 static void DoSaveFile(LPCWSTR wszSaveFileName
)
209 hFile
= CreateFileW(wszSaveFileName
, GENERIC_WRITE
, 0, NULL
, CREATE_ALWAYS
,
210 FILE_ATTRIBUTE_NORMAL
, NULL
);
212 if(hFile
== INVALID_HANDLE_VALUE
)
215 stream
.dwCookie
= (DWORD_PTR
)hFile
;
216 stream
.pfnCallback
= stream_out
;
218 /* FIXME: Handle different formats */
219 ret
= SendMessageW(hEditorWnd
, EM_STREAMOUT
, SF_RTF
, (LPARAM
)&stream
);
223 SetFocus(hEditorWnd
);
228 lstrcpyW(wszFileName
, wszSaveFileName
);
229 set_caption(wszFileName
);
232 static void HandleCommandLine(LPWSTR cmdline
)
237 /* skip white space */
238 while (*cmdline
== ' ') cmdline
++;
240 /* skip executable name */
241 delimiter
= (*cmdline
== '"' ? '"' : ' ');
243 if (*cmdline
== delimiter
) cmdline
++;
244 while (*cmdline
&& *cmdline
!= delimiter
) cmdline
++;
245 if (*cmdline
== delimiter
) cmdline
++;
247 while (*cmdline
== ' ' || *cmdline
== '-' || *cmdline
== '/')
251 if (*cmdline
++ == ' ') continue;
254 if (option
) cmdline
++;
255 while (*cmdline
== ' ') cmdline
++;
268 /* file name is passed on the command line */
269 if (cmdline
[0] == '"')
272 cmdline
[lstrlenW(cmdline
) - 1] = 0;
275 InvalidateRect(hMainWnd
, NULL
, FALSE
);
279 MessageBox(hMainWnd
, "Printing not implemented", "WordPad", MB_OK
);
282 static void DoDefaultFont(void)
284 static const WCHAR szFaceName
[] = {'T','i','m','e','s',' ','N','e','w',' ','R','o','m','a','n',0};
287 ZeroMemory(&fmt
, sizeof(fmt
));
289 fmt
.cbSize
= sizeof(fmt
);
290 fmt
.dwMask
= CFM_FACE
;
292 lstrcpyW(fmt
.szFaceName
, szFaceName
);
294 SendMessage(hEditorWnd
, EM_SETCHARFORMAT
, SCF_DEFAULT
, (LPARAM
)&fmt
);
297 static LRESULT
OnCreate( HWND hWnd
, WPARAM wParam
, LPARAM lParam
)
299 HWND hToolBarWnd
, hReBarWnd
;
300 HINSTANCE hInstance
= (HINSTANCE
)GetWindowLongPtr(hWnd
, GWLP_HINSTANCE
);
307 CreateStatusWindow(CCS_NODIVIDER
|WS_CHILD
|WS_VISIBLE
, "RichEdit text", hWnd
, IDC_STATUSBAR
);
309 hReBarWnd
= CreateWindowEx(WS_EX_TOOLWINDOW
, REBARCLASSNAME
, NULL
,
310 CCS_NODIVIDER
|WS_CHILD
|WS_VISIBLE
|WS_CLIPSIBLINGS
|WS_CLIPCHILDREN
|RBS_VARHEIGHT
|CCS_TOP
,
311 CW_USEDEFAULT
, CW_USEDEFAULT
, 0, 0, hWnd
, (HMENU
)IDC_REBAR
, hInstance
, NULL
);
313 rbi
.cbSize
= sizeof(rbi
);
316 if(!SendMessage(hReBarWnd
, RB_SETBARINFO
, 0, (LPARAM
)&rbi
))
319 hToolBarWnd
= CreateToolbarEx(hReBarWnd
, CCS_NOPARENTALIGN
|CCS_NOMOVEY
|WS_VISIBLE
|WS_CHILD
|TBSTYLE_TOOLTIPS
|TBSTYLE_BUTTON
,
321 6, hInstance
, IDB_TOOLBAR
,
323 24, 24, 16, 16, sizeof(TBBUTTON
));
325 ab
.hInst
= HINST_COMMCTRL
;
326 ab
.nID
= IDB_STD_SMALL_COLOR
;
327 nStdBitmaps
= SendMessage(hToolBarWnd
, TB_ADDBITMAP
, 6, (LPARAM
)&ab
);
328 AddButton(hToolBarWnd
, nStdBitmaps
+STD_FILENEW
, ID_FILE_NEW
);
329 AddButton(hToolBarWnd
, nStdBitmaps
+STD_FILEOPEN
, ID_FILE_OPEN
);
330 AddButton(hToolBarWnd
, nStdBitmaps
+STD_FILESAVE
, ID_FILE_SAVE
);
331 AddSeparator(hToolBarWnd
);
332 AddButton(hToolBarWnd
, nStdBitmaps
+STD_PRINT
, ID_PRINT
);
333 AddButton(hToolBarWnd
, nStdBitmaps
+STD_PRINTPRE
, ID_PREVIEW
);
334 AddSeparator(hToolBarWnd
);
335 AddButton(hToolBarWnd
, nStdBitmaps
+STD_FIND
, ID_FIND
);
336 AddSeparator(hToolBarWnd
);
337 AddButton(hToolBarWnd
, nStdBitmaps
+STD_CUT
, ID_EDIT_CUT
);
338 AddButton(hToolBarWnd
, nStdBitmaps
+STD_COPY
, ID_EDIT_COPY
);
339 AddButton(hToolBarWnd
, nStdBitmaps
+STD_PASTE
, ID_EDIT_PASTE
);
340 AddButton(hToolBarWnd
, nStdBitmaps
+STD_UNDO
, ID_EDIT_UNDO
);
341 AddButton(hToolBarWnd
, nStdBitmaps
+STD_REDOW
, ID_EDIT_REDO
);
342 AddSeparator(hToolBarWnd
);
343 AddButton(hToolBarWnd
, 0, ID_FORMAT_BOLD
);
344 AddButton(hToolBarWnd
, 1, ID_FORMAT_ITALIC
);
345 AddButton(hToolBarWnd
, 2, ID_FORMAT_UNDERLINE
);
346 AddSeparator(hToolBarWnd
);
347 AddButton(hToolBarWnd
, 3, ID_ALIGN_LEFT
);
348 AddButton(hToolBarWnd
, 4, ID_ALIGN_CENTER
);
349 AddButton(hToolBarWnd
, 5, ID_ALIGN_RIGHT
);
351 SendMessage(hToolBarWnd
, TB_ADDSTRING
, 0, (LPARAM
)"Exit\0");
352 SendMessage(hToolBarWnd
, TB_AUTOSIZE
, 0, 0);
354 rbb
.cbSize
= sizeof(rbb
);
355 rbb
.fMask
= RBBIM_SIZE
| RBBIM_CHILDSIZE
| RBBIM_CHILD
| RBBIM_STYLE
;
356 rbb
.fStyle
= RBBS_CHILDEDGE
;
358 rbb
.hwndChild
= hToolBarWnd
;
360 rbb
.cyChild
= rbb
.cyMinChild
= HIWORD(SendMessage(hToolBarWnd
, TB_GETBUTTONSIZE
, 0, 0));
362 SendMessage(hReBarWnd
, RB_INSERTBAND
, -1, (LPARAM
)&rbb
);
364 hDLL
= LoadLibrary("RICHED20.DLL");
367 hEditorWnd
= CreateWindowExW(WS_EX_CLIENTEDGE
, wszRichEditClass
, NULL
,
368 WS_CHILD
|WS_VISIBLE
|ES_MULTILINE
|ES_AUTOVSCROLL
|ES_WANTRETURN
|WS_VSCROLL
,
369 0, 0, 1000, 100, hWnd
, (HMENU
)IDC_EDITOR
, hInstance
, NULL
);
372 fprintf(stderr
, "Error code %u\n", GetLastError());
377 SetFocus(hEditorWnd
);
378 SendMessage(hEditorWnd
, EM_SETEVENTMASK
, 0, ENM_SELCHANGE
);
387 static LRESULT
OnUser( HWND hWnd
, WPARAM wParam
, LPARAM lParam
)
389 HWND hwndEditor
= GetDlgItem(hWnd
, IDC_EDITOR
);
390 HWND hwndReBar
= GetDlgItem(hWnd
, IDC_REBAR
);
391 HWND hwndToolBar
= GetDlgItem(hwndReBar
, IDC_TOOLBAR
);
396 ZeroMemory(&fmt
, sizeof(fmt
));
397 fmt
.cbSize
= sizeof(fmt
);
399 ZeroMemory(&pf
, sizeof(pf
));
400 pf
.cbSize
= sizeof(pf
);
402 SendMessage(hwndEditor
, EM_GETCHARFORMAT
, TRUE
, (LPARAM
)&fmt
);
404 SendMessage(hwndEditor
, EM_GETSEL
, (WPARAM
)&from
, (LPARAM
)&to
);
405 SendMessage(hwndToolBar
, TB_ENABLEBUTTON
, ID_EDIT_UNDO
,
406 SendMessage(hwndEditor
, EM_CANUNDO
, 0, 0));
407 SendMessage(hwndToolBar
, TB_ENABLEBUTTON
, ID_EDIT_REDO
,
408 SendMessage(hwndEditor
, EM_CANREDO
, 0, 0));
409 SendMessage(hwndToolBar
, TB_ENABLEBUTTON
, ID_EDIT_CUT
, from
== to
? 0 : 1);
410 SendMessage(hwndToolBar
, TB_ENABLEBUTTON
, ID_EDIT_COPY
, from
== to
? 0 : 1);
411 SendMessage(hwndToolBar
, TB_CHECKBUTTON
, ID_FORMAT_BOLD
, (fmt
.dwMask
& CFM_BOLD
) && (fmt
.dwEffects
& CFE_BOLD
));
412 SendMessage(hwndToolBar
, TB_INDETERMINATE
, ID_FORMAT_BOLD
, !(fmt
.dwMask
& CFM_BOLD
));
413 SendMessage(hwndToolBar
, TB_CHECKBUTTON
, ID_FORMAT_ITALIC
, (fmt
.dwMask
& CFM_ITALIC
) && (fmt
.dwEffects
& CFE_ITALIC
));
414 SendMessage(hwndToolBar
, TB_INDETERMINATE
, ID_FORMAT_ITALIC
, !(fmt
.dwMask
& CFM_ITALIC
));
415 SendMessage(hwndToolBar
, TB_CHECKBUTTON
, ID_FORMAT_UNDERLINE
, (fmt
.dwMask
& CFM_UNDERLINE
) && (fmt
.dwEffects
& CFE_UNDERLINE
));
416 SendMessage(hwndToolBar
, TB_INDETERMINATE
, ID_FORMAT_UNDERLINE
, !(fmt
.dwMask
& CFM_UNDERLINE
));
418 SendMessage(hwndEditor
, EM_GETPARAFORMAT
, 0, (LPARAM
)&pf
);
419 SendMessage(hwndToolBar
, TB_CHECKBUTTON
, ID_ALIGN_LEFT
, (pf
.wAlignment
== PFA_LEFT
));
420 SendMessage(hwndToolBar
, TB_CHECKBUTTON
, ID_ALIGN_CENTER
, (pf
.wAlignment
== PFA_CENTER
));
421 SendMessage(hwndToolBar
, TB_CHECKBUTTON
, ID_ALIGN_RIGHT
, (pf
.wAlignment
== PFA_RIGHT
));
426 static LRESULT
OnNotify( HWND hWnd
, WPARAM wParam
, LPARAM lParam
)
428 HWND hwndEditor
= GetDlgItem(hWnd
, IDC_EDITOR
);
429 NMHDR
*pHdr
= (NMHDR
*)lParam
;
431 if (pHdr
->hwndFrom
!= hwndEditor
)
434 if (pHdr
->code
== EN_SELCHANGE
)
436 SELCHANGE
*pSC
= (SELCHANGE
*)lParam
;
439 sprintf( buf
,"selection = %d..%d, line count=%ld",
440 pSC
->chrg
.cpMin
, pSC
->chrg
.cpMax
,
441 SendMessage(hwndEditor
, EM_GETLINECOUNT
, 0, 0));
442 SetWindowText(GetDlgItem(hWnd
, IDC_STATUSBAR
), buf
);
443 SendMessage(hWnd
, WM_USER
, 0, 0);
449 static LRESULT
OnCommand( HWND hWnd
, WPARAM wParam
, LPARAM lParam
)
451 HWND hwndEditor
= GetDlgItem(hWnd
, IDC_EDITOR
);
453 if ((HWND
)lParam
== hwndEditor
)
456 switch(LOWORD(wParam
))
459 PostMessage(hWnd
, WM_CLOSE
, 0, 0);
463 SetWindowTextA(hwndEditor
, "");
465 wszFileName
[0] = '\0';
466 /* FIXME: set default format too */
475 DoSaveFile(wszFileName
);
477 MessageBox(hWnd
, "Can only save existing for now", "WordPad", MB_OK
);
483 MessageBox(hWnd
, "Not implemented", "WordPad", MB_OK
);
487 case ID_FORMAT_ITALIC
:
488 case ID_FORMAT_UNDERLINE
:
492 if (LOWORD(wParam
) == ID_FORMAT_ITALIC
) mask
= CFM_ITALIC
;
493 if (LOWORD(wParam
) == ID_FORMAT_UNDERLINE
) mask
= CFM_UNDERLINE
;
495 ZeroMemory(&fmt
, sizeof(fmt
));
496 fmt
.cbSize
= sizeof(fmt
);
497 SendMessage(hwndEditor
, EM_GETCHARFORMAT
, SCF_SELECTION
, (LPARAM
)&fmt
);
498 if (!(fmt
.dwMask
&mask
))
499 fmt
.dwEffects
|= mask
;
501 fmt
.dwEffects
^= mask
;
503 SendMessage(hwndEditor
, EM_SETCHARFORMAT
, SCF_SELECTION
, (LPARAM
)&fmt
);
508 PostMessage(hwndEditor
, WM_CUT
, 0, 0);
512 PostMessage(hwndEditor
, WM_COPY
, 0, 0);
516 PostMessage(hwndEditor
, WM_PASTE
, 0, 0);
520 PostMessage(hwndEditor
, WM_CLEAR
, 0, 0);
523 case ID_EDIT_SELECTALL
:
525 CHARRANGE range
= {0, -1};
526 SendMessage(hwndEditor
, EM_EXSETSEL
, 0, (LPARAM
)&range
);
527 /* SendMessage(hwndEditor, EM_SETSEL, 0, -1); */
531 case ID_EDIT_GETTEXT
:
533 int nLen
= GetWindowTextLengthW(hwndEditor
);
534 LPWSTR data
= HeapAlloc( GetProcessHeap(), 0, (nLen
+1)*sizeof(WCHAR
) );
537 GetWindowTextW(hwndEditor
, data
, nLen
+1);
538 MessageBoxW(NULL
, data
, xszAppTitle
, MB_OK
);
540 HeapFree( GetProcessHeap(), 0, data
);
541 data
= HeapAlloc(GetProcessHeap(), 0, (nLen
+1)*sizeof(WCHAR
));
543 tr
.chrg
.cpMax
= nLen
;
545 SendMessage (hwndEditor
, EM_GETTEXTRANGE
, 0, (LPARAM
)&tr
);
546 MessageBoxW(NULL
, data
, xszAppTitle
, MB_OK
);
547 HeapFree( GetProcessHeap(), 0, data
);
549 /* SendMessage(hwndEditor, EM_SETSEL, 0, -1); */
553 case ID_EDIT_CHARFORMAT
:
554 case ID_EDIT_DEFCHARFORMAT
:
558 ZeroMemory(&cf
, sizeof(cf
));
559 cf
.cbSize
= sizeof(cf
);
561 i
= SendMessage(hwndEditor
, EM_GETCHARFORMAT
,
562 LOWORD(wParam
) == ID_EDIT_CHARFORMAT
, (LPARAM
)&cf
);
566 case ID_EDIT_PARAFORMAT
:
569 ZeroMemory(&pf
, sizeof(pf
));
570 pf
.cbSize
= sizeof(pf
);
571 SendMessage(hwndEditor
, EM_GETPARAFORMAT
, 0, (LPARAM
)&pf
);
575 case ID_EDIT_SELECTIONINFO
:
577 CHARRANGE range
= {0, -1};
581 SendMessage(hwndEditor
, EM_EXGETSEL
, 0, (LPARAM
)&range
);
582 data
= HeapAlloc(GetProcessHeap(), 0, sizeof(*data
) * (range
.cpMax
-range
.cpMin
+1));
583 SendMessage(hwndEditor
, EM_GETSELTEXT
, 0, (LPARAM
)data
);
584 sprintf(buf
, "Start = %d, End = %d", range
.cpMin
, range
.cpMax
);
585 MessageBoxA(hWnd
, buf
, "Editor", MB_OK
);
586 MessageBoxW(hWnd
, data
, xszAppTitle
, MB_OK
);
587 HeapFree( GetProcessHeap(), 0, data
);
588 /* SendMessage(hwndEditor, EM_SETSEL, 0, -1); */
592 case ID_EDIT_READONLY
:
594 long nStyle
= GetWindowLong(hwndEditor
, GWL_STYLE
);
595 if (nStyle
& ES_READONLY
)
596 SendMessage(hwndEditor
, EM_SETREADONLY
, 0, 0);
598 SendMessage(hwndEditor
, EM_SETREADONLY
, 1, 0);
602 case ID_EDIT_MODIFIED
:
603 if (SendMessage(hwndEditor
, EM_GETMODIFY
, 0, 0))
604 SendMessage(hwndEditor
, EM_SETMODIFY
, 0, 0);
606 SendMessage(hwndEditor
, EM_SETMODIFY
, 1, 0);
610 SendMessage(hwndEditor
, EM_UNDO
, 0, 0);
614 SendMessage(hwndEditor
, EM_REDO
, 0, 0);
618 case ID_ALIGN_CENTER
:
623 pf
.cbSize
= sizeof(pf
);
624 pf
.dwMask
= PFM_ALIGNMENT
;
625 switch(LOWORD(wParam
)) {
626 case ID_ALIGN_LEFT
: pf
.wAlignment
= PFA_LEFT
; break;
627 case ID_ALIGN_CENTER
: pf
.wAlignment
= PFA_CENTER
; break;
628 case ID_ALIGN_RIGHT
: pf
.wAlignment
= PFA_RIGHT
; break;
630 SendMessage(hwndEditor
, EM_SETPARAFORMAT
, 0, (LPARAM
)&pf
);
635 SendMessage(hwndEditor
, EM_SETBKGNDCOLOR
, 1, 0);
639 SendMessage(hwndEditor
, EM_SETBKGNDCOLOR
, 0, RGB(255,255,192));
643 SendMessage(hwndEditor
, WM_COMMAND
, wParam
, lParam
);
649 static LRESULT
OnInitPopupMenu( HWND hWnd
, WPARAM wParam
, LPARAM lParam
)
651 HMENU hMenu
= (HMENU
)wParam
;
652 HWND hwndEditor
= GetDlgItem(hWnd
, IDC_EDITOR
);
656 pf
.cbSize
= sizeof(PARAFORMAT
);
657 SendMessage(hwndEditor
, EM_GETPARAFORMAT
, 0, (LPARAM
)&pf
);
658 CheckMenuItem(hMenu
, ID_EDIT_READONLY
,
659 MF_BYCOMMAND
|(GetWindowLong(hwndEditor
, GWL_STYLE
)&ES_READONLY
? MF_CHECKED
: MF_UNCHECKED
));
660 CheckMenuItem(hMenu
, ID_EDIT_MODIFIED
,
661 MF_BYCOMMAND
|(SendMessage(hwndEditor
, EM_GETMODIFY
, 0, 0) ? MF_CHECKED
: MF_UNCHECKED
));
662 if (pf
.dwMask
& PFM_ALIGNMENT
)
663 nAlignment
= pf
.wAlignment
;
664 CheckMenuItem(hMenu
, ID_ALIGN_LEFT
, MF_BYCOMMAND
|(nAlignment
== PFA_LEFT
) ? MF_CHECKED
: MF_UNCHECKED
);
665 CheckMenuItem(hMenu
, ID_ALIGN_CENTER
, MF_BYCOMMAND
|(nAlignment
== PFA_CENTER
) ? MF_CHECKED
: MF_UNCHECKED
);
666 CheckMenuItem(hMenu
, ID_ALIGN_RIGHT
, MF_BYCOMMAND
|(nAlignment
== PFA_RIGHT
) ? MF_CHECKED
: MF_UNCHECKED
);
667 EnableMenuItem(hMenu
, ID_EDIT_UNDO
, MF_BYCOMMAND
|(SendMessage(hwndEditor
, EM_CANUNDO
, 0, 0)) ? MF_ENABLED
: MF_GRAYED
);
668 EnableMenuItem(hMenu
, ID_EDIT_REDO
, MF_BYCOMMAND
|(SendMessage(hwndEditor
, EM_CANREDO
, 0, 0)) ? MF_ENABLED
: MF_GRAYED
);
672 static LRESULT
OnSize( HWND hWnd
, WPARAM wParam
, LPARAM lParam
)
674 int nStatusSize
= 0, nTBSize
= 0;
676 HWND hwndEditor
= GetDlgItem(hWnd
, IDC_EDITOR
);
677 HWND hwndStatusBar
= GetDlgItem(hWnd
, IDC_STATUSBAR
);
678 HWND hwndReBar
= GetDlgItem(hWnd
, IDC_REBAR
);
679 HWND hwndToolBar
= GetDlgItem(hwndReBar
, IDC_TOOLBAR
);
683 SendMessage(hwndStatusBar
, WM_SIZE
, 0, 0);
684 GetClientRect(hwndStatusBar
, &rc
);
685 nStatusSize
= rc
.bottom
- rc
.top
;
689 rc
.left
= rc
.top
= 0;
690 rc
.right
= LOWORD(lParam
);
691 rc
.bottom
= HIWORD(lParam
);
692 SendMessage(hwndToolBar
, TB_AUTOSIZE
, 0, 0);
693 SendMessage(hwndReBar
, RB_SIZETORECT
, 0, (LPARAM
)&rc
);
694 nTBSize
= SendMessage(hwndReBar
, RB_GETBARHEIGHT
, 0, 0);
695 GetClientRect(hwndReBar
, &rc
);
696 MoveWindow(hwndReBar
, 0, 0, LOWORD(lParam
), rc
.right
, FALSE
);
700 GetClientRect(hWnd
, &rc
);
701 MoveWindow(hwndEditor
, 0, nTBSize
, rc
.right
, rc
.bottom
-nStatusSize
-nTBSize
, TRUE
);
704 return DefWindowProcW(hWnd
, WM_SIZE
, wParam
, lParam
);
707 static LRESULT CALLBACK
WndProc(HWND hWnd
, UINT msg
, WPARAM wParam
, LPARAM lParam
)
712 return OnCreate( hWnd
, wParam
, lParam
);
715 return OnUser( hWnd
, wParam
, lParam
);
718 return OnNotify( hWnd
, wParam
, lParam
);
721 return OnCommand( hWnd
, wParam
, lParam
);
729 SetFocus(GetDlgItem(hWnd
, IDC_EDITOR
));
732 case WM_INITMENUPOPUP
:
733 return OnInitPopupMenu( hWnd
, wParam
, lParam
);
736 return OnSize( hWnd
, wParam
, lParam
);
739 return DefWindowProcW(hWnd
, msg
, wParam
, lParam
);
745 int CALLBACK
WinMain(HINSTANCE hInstance
, HINSTANCE hOldInstance
, LPSTR szCmdParagraph
, int res
)
747 INITCOMMONCONTROLSEX classes
= {8, ICC_BAR_CLASSES
|ICC_COOL_CLASSES
};
752 InitCommonControlsEx(&classes
);
754 hAccel
= LoadAccelerators(hInstance
, "MAINACCELTABLE");
756 wc
.style
= CS_HREDRAW
| CS_VREDRAW
;
757 wc
.lpfnWndProc
= WndProc
;
760 wc
.hInstance
= hInstance
;
761 wc
.hIcon
= LoadIconW(hInstance
, MAKEINTRESOURCEW(IDI_WORDPAD
));
762 wc
.hCursor
= LoadCursor(NULL
, IDC_IBEAM
);
763 wc
.hbrBackground
= GetSysColorBrush(COLOR_WINDOW
);
764 wc
.lpszMenuName
= xszMainMenu
;
765 wc
.lpszClassName
= wszMainWndClass
;
768 hMainWnd
= CreateWindowExW(0, wszMainWndClass
, wszAppTitle
, WS_OVERLAPPEDWINDOW
,
769 CW_USEDEFAULT
, CW_USEDEFAULT
, 680, 260, NULL
, NULL
, hInstance
, NULL
);
770 ShowWindow(hMainWnd
, SW_SHOWDEFAULT
);
772 HandleCommandLine(GetCommandLineW());
774 while(GetMessage(&msg
,0,0,0))
776 if (TranslateAccelerator(hMainWnd
, hAccel
, &msg
))
778 TranslateMessage(&msg
);
779 DispatchMessage(&msg
);
780 if (!PeekMessage(&msg
, 0, 0, 0, PM_NOREMOVE
))
781 SendMessage(hMainWnd
, WM_USER
, 0, 0);