ReactOS 0.4.16-dev-2104-gb84fa49
taskswnd.cpp
Go to the documentation of this file.
1/*
2 * ReactOS Explorer
3 *
4 * Copyright 2006 - 2007 Thomas Weidenmueller <w3seek@reactos.org>
5 *
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.
10 *
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.
15 *
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 Street, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20
21#include "precomp.h"
22#include <commoncontrols.h>
23#include <regstr.h>
24#include <shlwapi_undoc.h>
25
26/* Set DUMP_TASKS to 1 to enable a dump of the tasks and task groups every
27 5 seconds */
28#define DUMP_TASKS 0
29#define DEBUG_SHELL_HOOK 0
30
31#define MAX_TASKS_COUNT (0x7FFF)
32#define TASK_ITEM_ARRAY_ALLOC 64
33
34//************************************************************************
35// Fullscreen windows (a.k.a. rude apps) checker
36
37#define TIMER_ID_VALIDATE_RUDE_APP 5
38#define VALIDATE_RUDE_INTERVAL 1000
39#define VALIDATE_RUDE_MAX_COUNT 5
40
41static BOOL
43 _In_opt_ HMONITOR hMonitor,
44 _Out_opt_ PRECT prcDest,
45 _In_ BOOL bWorkAreaOnly)
46{
47 MONITORINFO mi = { sizeof(mi) };
48 if (!hMonitor || !::GetMonitorInfoW(hMonitor, &mi))
49 {
50 if (!prcDest)
51 return FALSE;
52
53 if (bWorkAreaOnly)
54 ::SystemParametersInfoW(SPI_GETWORKAREA, 0, prcDest, 0);
55 else
56 ::SetRect(prcDest, 0, 0, GetSystemMetrics(SM_CXSCREEN), GetSystemMetrics(SM_CYSCREEN));
57
58 return FALSE;
59 }
60
61 if (prcDest)
62 *prcDest = (bWorkAreaOnly ? mi.rcWork : mi.rcMonitor);
63 return TRUE;
64}
65
66static BOOL
68{
69 for (; hWnd; hWnd = ::GetParent(hWnd))
70 {
71 if (hWnd == hwndTarget)
72 return TRUE;
73 }
74 return FALSE;
75}
76
77static BOOL
79{
80 HWND hwndFore = ::GetForegroundWindow();
82 return dwThreadId == ::GetWindowThreadProcessId(hwndFore, NULL) ||
84}
85
86static BOOL
88{
90 return FALSE;
91
92 RECT rcMonitor;
93 SHELL_GetMonitorRect(hMonitor, &rcMonitor, FALSE);
94
96
97 RECT rcWnd;
98 enum { CHECK_STYLE = WS_THICKFRAME | WS_DLGFRAME | WS_BORDER };
99 if ((style & CHECK_STYLE) == CHECK_STYLE)
100 {
101 ::GetClientRect(hWnd, &rcWnd); // Ignore frame
102 ::MapWindowPoints(hWnd, NULL, (PPOINT)&rcWnd, sizeof(RECT) / sizeof(POINT));
103 }
104 else
105 {
106 ::GetWindowRect(hWnd, &rcWnd);
107 }
108
109 RECT rcUnion;
110 ::UnionRect(&rcUnion, &rcWnd, &rcMonitor);
111
112 return ::EqualRect(&rcUnion, &rcWnd) && (bDontCheckActive || SHELL_IsRudeWindowActive(hWnd));
113}
114
116
117const WCHAR szTaskSwitchWndClass[] = L"MSTaskSwWClass";
118const WCHAR szRunningApps[] = L"Running Applications";
119
120#if DEBUG_SHELL_HOOK
121const struct {
122 INT msg;
123 LPCWSTR msg_name;
124} hshell_msg [] = {
125 { HSHELL_WINDOWCREATED, L"HSHELL_WINDOWCREATED" },
126 { HSHELL_WINDOWDESTROYED, L"HSHELL_WINDOWDESTROYED" },
127 { HSHELL_ACTIVATESHELLWINDOW, L"HSHELL_ACTIVATESHELLWINDOW" },
128 { HSHELL_WINDOWACTIVATED, L"HSHELL_WINDOWACTIVATED" },
129 { HSHELL_GETMINRECT, L"HSHELL_GETMINRECT" },
130 { HSHELL_REDRAW, L"HSHELL_REDRAW" },
131 { HSHELL_TASKMAN, L"HSHELL_TASKMAN" },
132 { HSHELL_LANGUAGE, L"HSHELL_LANGUAGE" },
133 { HSHELL_SYSMENU, L"HSHELL_SYSMENU" },
134 { HSHELL_ENDTASK, L"HSHELL_ENDTASK" },
135 { HSHELL_ACCESSIBILITYSTATE, L"HSHELL_ACCESSIBILITYSTATE" },
136 { HSHELL_APPCOMMAND, L"HSHELL_APPCOMMAND" },
137 { HSHELL_WINDOWREPLACED, L"HSHELL_WINDOWREPLACED" },
138 { HSHELL_WINDOWREPLACING, L"HSHELL_WINDOWREPLACING" },
139 { HSHELL_RUDEAPPACTIVATED, L"HSHELL_RUDEAPPACTIVATED" },
140};
141#endif
142
143typedef struct _TASK_GROUP
144{
145 /* We have to use a linked list instead of an array so we don't have to
146 update all pointers to groups in the task item array when removing
147 groups. */
149
153 union
154 {
156 struct
157 {
158
160 };
161 };
163
164typedef struct _TASK_ITEM
165{
170
171 union
172 {
174 struct
175 {
176
177 /* IsFlashing is TRUE when the task bar item should be flashing. */
179
180 /* RenderFlashed is only TRUE if the task bar item should be
181 drawn with a flash. */
183 };
184 };
186
187
189{
197public:
198
200 m_ThreadId(0),
203 m_Status(NULL),
205 {
206 }
207
209 {
211 {
212 /* Try to unstuck Show */
215 if (ret == WAIT_TIMEOUT)
218 }
219 }
220
222 {
223 HRESULT hr;
224 CComPtr<IUserNotification> pnotification;
225
228 return hr;
229
230 hr = CoCreateInstance(CLSID_UserNotification,
231 NULL,
232 CLSCTX_INPROC_SERVER,
233 IID_PPV_ARG(IUserNotification, &pnotification));
235 return hr;
236
237 hr = pnotification->SetBalloonInfo(m_Title, m_Text, NIIF_WARNING);
239 return hr;
240
241 hr = pnotification->SetIconInfo(NULL, NULL);
243 return hr;
244
245 /* Show will block until the balloon closes */
246 hr = pnotification->Show(NULL, 0);
248 return hr;
249
250 return S_OK;
251 }
252
254 {
255 CHardErrorThread* pThis = reinterpret_cast<CHardErrorThread*>(lpParameter);
256 pThis->ThreadProc();
257 CloseHandle(pThis->m_hThread);
260 return 0;
261 }
262
264 {
266
267 /* Ignore the new message if we are already showing one */
268 if (bIsRunning)
269 return;
270
271 m_Status = pData->Status;
272 m_dwType = pData->dwType;
273 m_Title = (PWCHAR)((ULONG_PTR)pData + pData->TitleOffset);
274 m_Text = (PWCHAR)((ULONG_PTR)pData + pData->MessageOffset);
276 if (!m_hThread)
277 {
279 }
280 }
281};
282
284 public CWindowImplBaseT< CToolbar<TASK_ITEM>, CControlWinTraits >
285{
286public:
287 INT UpdateTbButtonSpacing(IN BOOL bHorizontal, IN BOOL bThemed, IN UINT uiRows = 0, IN UINT uiBtnsPerLine = 0)
288 {
289 TBMETRICS tbm;
290
291 tbm.cbSize = sizeof(tbm);
293
294 tbm.cxBarPad = tbm.cyBarPad = 0;
295
296 if (bThemed)
297 {
298 tbm.cxButtonSpacing = 0;
299 tbm.cyButtonSpacing = 0;
300 }
301 else
302 {
303 if (bHorizontal || uiBtnsPerLine > 1)
305 else
306 tbm.cxButtonSpacing = 0;
307
308 if (!bHorizontal || uiRows > 1)
310 else
311 tbm.cyButtonSpacing = 0;
312 }
313
314 SetMetrics(&tbm);
315
316 return tbm.cxButtonSpacing;
317 }
318
320 {
322 }
323
325 {
328 }
329
330 BOOL SetButtonCommandId(IN INT iButtonIndex, IN INT iCommandId)
331 {
332 TBBUTTONINFO tbbi;
333
334 tbbi.cbSize = sizeof(tbbi);
335 tbbi.dwMask = TBIF_BYINDEX | TBIF_COMMAND;
336 tbbi.idCommand = iCommandId;
337
338 return SetButtonInfo(iButtonIndex, &tbbi) != 0;
339 }
340
342 {
343 POINT pt;
344
345 /* See if the mouse is on a button */
349
350 INT index = HitTest(&pt);
351 if (index < 0)
352 {
353 /* Make the control appear to be transparent outside of any buttons */
354 return HTTRANSPARENT;
355 }
356
357 bHandled = FALSE;
358 return 0;
359 }
360
361public:
365
367 {
371
372 // HACK & FIXME: CORE-18016
373 HWND toolbar = CToolbar::Create(hWndParent, styles);
374 m_hWnd = NULL;
375 return SubclassWindow(toolbar);
376 }
377};
378
380 public CComCoClass<CTaskSwitchWnd>,
381 public CComObjectRootEx<CComMultiThreadModelNoCS>,
382 public CWindowImpl < CTaskSwitchWnd, CWindow, CControlWinTraits >,
383 public IOleWindow
384{
386
388
390
393
397
401
403
406
408
410
413
414public:
422 m_Theme(NULL),
424 m_ButtonCount(0),
429 {
432 }
433 virtual ~CTaskSwitchWnd() { }
434
436 {
437 /* Get the window text without sending a message so we don't hang if an
438 application isn't responding! */
439 return InternalGetWindowText(TaskItem->hWnd, szBuf, cchBuf);
440 }
441
442
443#if DUMP_TASKS != 0
444 VOID DumpTasks()
445 {
446 PTASK_GROUP CurrentGroup;
447 PTASK_ITEM CurrentTaskItem, LastTaskItem;
448
449 TRACE("Tasks dump:\n");
451 {
452 CurrentGroup = m_TaskGroups;
453 while (CurrentGroup != NULL)
454 {
455 TRACE("- Group PID: 0x%p Tasks: %d Index: %d\n", CurrentGroup->dwProcessId, CurrentGroup->dwTaskCount, CurrentGroup->Index);
456
457 CurrentTaskItem = m_TaskItems;
458 LastTaskItem = CurrentTaskItem + m_TaskItemCount;
459 while (CurrentTaskItem != LastTaskItem)
460 {
461 if (CurrentTaskItem->Group == CurrentGroup)
462 {
463 TRACE(" + Task hwnd: 0x%p Index: %d\n", CurrentTaskItem->hWnd, CurrentTaskItem->Index);
464 }
465 CurrentTaskItem++;
466 }
467
468 CurrentGroup = CurrentGroup->Next;
469 }
470
471 CurrentTaskItem = m_TaskItems;
472 LastTaskItem = CurrentTaskItem + m_TaskItemCount;
473 while (CurrentTaskItem != LastTaskItem)
474 {
475 if (CurrentTaskItem->Group == NULL)
476 {
477 TRACE("- Task hwnd: 0x%p Index: %d\n", CurrentTaskItem->hWnd, CurrentTaskItem->Index);
478 }
479 CurrentTaskItem++;
480 }
481 }
482 else
483 {
484 CurrentTaskItem = m_TaskItems;
485 LastTaskItem = CurrentTaskItem + m_TaskItemCount;
486 while (CurrentTaskItem != LastTaskItem)
487 {
488 TRACE("- Task hwnd: 0x%p Index: %d\n", CurrentTaskItem->hWnd, CurrentTaskItem->Index);
489 CurrentTaskItem++;
490 }
491 }
492 }
493#endif
494
495 VOID UpdateIndexesAfter(IN INT iIndex, BOOL bInserted)
496 {
497 PTASK_GROUP CurrentGroup;
498 PTASK_ITEM CurrentTaskItem, LastTaskItem;
499 INT NewIndex;
500
501 int offset = bInserted ? +1 : -1;
502
504 {
505 /* Update all affected groups */
506 CurrentGroup = m_TaskGroups;
507 while (CurrentGroup != NULL)
508 {
509 if (CurrentGroup->IsCollapsed &&
510 CurrentGroup->Index >= iIndex)
511 {
512 /* Update the toolbar buttons */
513 NewIndex = CurrentGroup->Index + offset;
514 if (m_TaskBar.SetButtonCommandId(CurrentGroup->Index + offset, NewIndex))
515 {
516 CurrentGroup->Index = NewIndex;
517 }
518 else
519 CurrentGroup->Index = -1;
520 }
521
522 CurrentGroup = CurrentGroup->Next;
523 }
524 }
525
526 /* Update all affected task items */
527 CurrentTaskItem = m_TaskItems;
528 LastTaskItem = CurrentTaskItem + m_TaskItemCount;
529 while (CurrentTaskItem != LastTaskItem)
530 {
531 CurrentGroup = CurrentTaskItem->Group;
532 if (CurrentGroup != NULL)
533 {
534 if (!CurrentGroup->IsCollapsed &&
535 CurrentTaskItem->Index >= iIndex)
536 {
537 goto UpdateTaskItemBtn;
538 }
539 }
540 else if (CurrentTaskItem->Index >= iIndex)
541 {
542 UpdateTaskItemBtn:
543 /* Update the toolbar buttons */
544 NewIndex = CurrentTaskItem->Index + offset;
545 if (m_TaskBar.SetButtonCommandId(CurrentTaskItem->Index + offset, NewIndex))
546 {
547 CurrentTaskItem->Index = NewIndex;
548 }
549 else
550 CurrentTaskItem->Index = -1;
551 }
552
553 CurrentTaskItem++;
554 }
555 }
556
557
559 {
560 ASSERT(TaskGroup->Index >= 0);
561
562 /* FIXME: Implement */
563
564 return TaskGroup->Index;
565 }
566
568 {
569 ASSERT(TaskGroup->dwTaskCount > 0);
570 ASSERT(TaskGroup->IsCollapsed);
571 ASSERT(TaskGroup->Index >= 0);
572
573 /* FIXME: Implement */
574 }
575
577 {
578 HICON hIcon = NULL;
579
580 /* Retrieve icon by sending a message */
581#define GET_ICON(type) \
582 SendMessageTimeout(hwnd, WM_GETICON, (type), 0, SMTO_NOTIMEOUTIFNOTHUNG, 100, (PDWORD_PTR)&hIcon)
583
584 LRESULT bAlive = GET_ICON(g_TaskbarSettings.bSmallIcons ? ICON_SMALL2 : ICON_BIG);
585 if (hIcon)
586 return hIcon;
587
588 if (bAlive)
589 {
590 bAlive = GET_ICON(ICON_SMALL);
591 if (hIcon)
592 return hIcon;
593 }
594
595 if (bAlive)
596 {
598 if (hIcon)
599 return hIcon;
600 }
601#undef GET_ICON
602
603 /* If we failed, retrieve icon from the window class */
605 if (hIcon)
606 return hIcon;
607
609 }
610
612 {
613 TBBUTTONINFO tbbi = { 0 };
614 HICON icon;
615 WCHAR windowText[255];
616
617 ASSERT(TaskItem->Index >= 0);
618
619 tbbi.cbSize = sizeof(tbbi);
620 tbbi.dwMask = TBIF_BYINDEX | TBIF_STATE | TBIF_TEXT | TBIF_IMAGE;
621 tbbi.fsState = TBSTATE_ENABLED;
622 if (m_ActiveTaskItem == TaskItem)
623 tbbi.fsState |= TBSTATE_CHECKED;
624
625 if (TaskItem->RenderFlashed)
626 tbbi.fsState |= TBSTATE_MARKED;
627
628 /* Check if we're updating a button that is the last one in the
629 line. If so, we need to set the TBSTATE_WRAP flag! */
630 if (!m_Tray->IsHorizontal() || (m_ButtonsPerLine != 0 &&
631 (TaskItem->Index + 1) % m_ButtonsPerLine == 0))
632 {
633 tbbi.fsState |= TBSTATE_WRAP;
634 }
635
637 {
638 tbbi.pszText = windowText;
639 }
640
641 icon = GetWndIcon(TaskItem->hWnd);
642 if (!icon)
643 icon = static_cast<HICON>(LoadImageW(NULL, MAKEINTRESOURCEW(OIC_SAMPLE), IMAGE_ICON, 0, 0, LR_SHARED | LR_DEFAULTSIZE));
644 TaskItem->IconIndex = ImageList_ReplaceIcon(m_ImageList, TaskItem->IconIndex, icon);
645 tbbi.iImage = TaskItem->IconIndex;
646
647 if (!m_TaskBar.SetButtonInfo(TaskItem->Index, &tbbi))
648 {
649 TaskItem->Index = -1;
650 return -1;
651 }
652
653 TRACE("Updated button %d for hwnd 0x%p\n", TaskItem->Index, TaskItem->hWnd);
654 return TaskItem->Index;
655 }
656
658 {
659 TBBUTTONINFO tbbi;
660 PTASK_ITEM currentTaskItem, LastItem;
661
662 if (TaskItem->IconIndex == -1)
663 return;
664
665 tbbi.cbSize = sizeof(tbbi);
666 tbbi.dwMask = TBIF_IMAGE;
667
668 currentTaskItem = m_TaskItems;
669 LastItem = currentTaskItem + m_TaskItemCount;
670 while (currentTaskItem != LastItem)
671 {
672 if (currentTaskItem->IconIndex > TaskItem->IconIndex)
673 {
674 currentTaskItem->IconIndex--;
675 tbbi.iImage = currentTaskItem->IconIndex;
676
677 m_TaskBar.SetButtonInfo(currentTaskItem->Index, &tbbi);
678 }
679 currentTaskItem++;
680 }
681
682 ImageList_Remove(m_ImageList, TaskItem->IconIndex);
683 }
684
686 IN PTASK_GROUP TaskGroup OPTIONAL,
687 IN PTASK_ITEM NewTaskItem OPTIONAL)
688 {
689 PTASK_ITEM TaskItem, LastTaskItem, FoundTaskItem = NULL;
690 DWORD dwTaskCount;
691
693
694 TaskItem = m_TaskItems;
695 LastTaskItem = TaskItem + m_TaskItemCount;
696
697 dwTaskCount = (TaskGroup != NULL ? TaskGroup->dwTaskCount : MAX_TASKS_COUNT);
698
699 ASSERT(dwTaskCount > 0);
700
701 while (TaskItem != LastTaskItem)
702 {
703 if (TaskItem->Group == TaskGroup)
704 {
705 if ((NewTaskItem != NULL && TaskItem != NewTaskItem) || NewTaskItem == NULL)
706 {
707 FoundTaskItem = TaskItem;
708 }
709
710 if (--dwTaskCount == 0)
711 {
712 /* We found the last task item in the group! */
713 break;
714 }
715 }
716
717 TaskItem++;
718 }
719
720 return FoundTaskItem;
721 }
722
724 {
725 PTASK_GROUP TaskGroup;
726 PTASK_ITEM LastTaskItem;
727
728 /* NOTE: This routine assumes that the group is *not* collapsed! */
729
730 TaskGroup = TaskItem->Group;
732 {
733 if (TaskGroup != NULL)
734 {
735 ASSERT(TaskGroup->Index < 0);
736 ASSERT(!TaskGroup->IsCollapsed);
737
738 if (TaskGroup->dwTaskCount > 1)
739 {
740 LastTaskItem = FindLastTaskItemOfGroup(TaskGroup, TaskItem);
741 if (LastTaskItem != NULL)
742 {
743 /* Since the group is expanded the task items must have an index */
744 ASSERT(LastTaskItem->Index >= 0);
745
746 return LastTaskItem->Index + 1;
747 }
748 }
749 }
750 else
751 {
752 /* Find the last NULL group button. NULL groups are added at the end of the
753 task item list when grouping is enabled */
754 LastTaskItem = FindLastTaskItemOfGroup(NULL, TaskItem);
755 if (LastTaskItem != NULL)
756 {
757 ASSERT(LastTaskItem->Index >= 0);
758
759 return LastTaskItem->Index + 1;
760 }
761 }
762 }
763
764 return m_ButtonCount;
765 }
766
768 {
769 WCHAR windowText[255];
770 TBBUTTON tbBtn = { 0 };
771 INT iIndex;
772 HICON icon;
773
774 if (TaskItem->Index >= 0)
775 {
776 return UpdateTaskItemButton(TaskItem);
777 }
778
779 if (TaskItem->Group != NULL &&
780 TaskItem->Group->IsCollapsed)
781 {
782 /* The task group is collapsed, we only need to update the group button */
783 return UpdateTaskGroupButton(TaskItem->Group);
784 }
785
786 icon = GetWndIcon(TaskItem->hWnd);
787 if (!icon)
788 icon = static_cast<HICON>(LoadImageW(NULL, MAKEINTRESOURCEW(OIC_SAMPLE), IMAGE_ICON, 0, 0, LR_SHARED | LR_DEFAULTSIZE));
789 TaskItem->IconIndex = ImageList_ReplaceIcon(m_ImageList, -1, icon);
790
791 tbBtn.iBitmap = TaskItem->IconIndex;
794 tbBtn.dwData = TaskItem->Index;
795
797 {
798 tbBtn.iString = (DWORD_PTR) windowText;
799 }
800
801 /* Find out where to insert the new button */
802 iIndex = CalculateTaskItemNewButtonIndex(TaskItem);
803 ASSERT(iIndex >= 0);
804 tbBtn.idCommand = iIndex;
805
807
808 if (m_TaskBar.InsertButton(iIndex, &tbBtn))
809 {
810 UpdateIndexesAfter(iIndex, TRUE);
811
812 TRACE("Added button %d for hwnd 0x%p\n", iIndex, TaskItem->hWnd);
813
814 TaskItem->Index = iIndex;
816
817 /* Update button sizes and fix the button wrapping */
819 return iIndex;
820 }
821
823
824 return -1;
825 }
826
828 {
829 PTASK_GROUP TaskGroup;
830 INT iIndex;
831
832 TaskGroup = TaskItem->Group;
833
834 if (TaskItem->Index >= 0)
835 {
836 if ((TaskGroup != NULL && !TaskGroup->IsCollapsed) ||
837 TaskGroup == NULL)
838 {
840
841 RemoveIcon(TaskItem);
842 iIndex = TaskItem->Index;
843 if (m_TaskBar.DeleteButton(iIndex))
844 {
845 TaskItem->Index = -1;
847
848 UpdateIndexesAfter(iIndex, FALSE);
849
850 /* Update button sizes and fix the button wrapping */
852 return TRUE;
853 }
854
856 }
857 }
858
859 return FALSE;
860 }
861
863 {
865 PTASK_GROUP TaskGroup, *PrevLink;
866
868 &dwProcessId))
869 {
870 TRACE("Cannot get process id of hwnd 0x%p\n", hWnd);
871 return NULL;
872 }
873
874 /* Try to find an existing task group */
875 TaskGroup = m_TaskGroups;
876 PrevLink = &m_TaskGroups;
877 while (TaskGroup != NULL)
878 {
879 if (TaskGroup->dwProcessId == dwProcessId)
880 {
881 TaskGroup->dwTaskCount++;
882 return TaskGroup;
883 }
884
885 PrevLink = &TaskGroup->Next;
886 TaskGroup = TaskGroup->Next;
887 }
888
889 /* Allocate a new task group */
890 TaskGroup = (PTASK_GROUP) HeapAlloc(hProcessHeap,
892 sizeof(*TaskGroup));
893 if (TaskGroup != NULL)
894 {
895 TaskGroup->dwTaskCount = 1;
896 TaskGroup->dwProcessId = dwProcessId;
897 TaskGroup->Index = -1;
898
899 /* Add the task group to the list */
900 *PrevLink = TaskGroup;
901 }
902
903 return TaskGroup;
904 }
905
907 {
908 PTASK_GROUP TaskGroup, CurrentGroup, *PrevLink;
909
910 TaskGroup = TaskItem->Group;
911 if (TaskGroup != NULL)
912 {
913 DWORD dwNewTaskCount = --TaskGroup->dwTaskCount;
914 if (dwNewTaskCount == 0)
915 {
916 /* Find the previous pointer in the chain */
917 CurrentGroup = m_TaskGroups;
918 PrevLink = &m_TaskGroups;
919 while (CurrentGroup != TaskGroup)
920 {
921 PrevLink = &CurrentGroup->Next;
922 CurrentGroup = CurrentGroup->Next;
923 }
924
925 /* Remove the group from the list */
926 ASSERT(TaskGroup == CurrentGroup);
927 *PrevLink = TaskGroup->Next;
928
929 /* Free the task group */
931 0,
932 TaskGroup);
933 }
934 else if (TaskGroup->IsCollapsed &&
935 TaskGroup->Index >= 0)
936 {
937 if (dwNewTaskCount > 1)
938 {
939 /* FIXME: Check if we should expand the group */
940 /* Update the task group button */
941 UpdateTaskGroupButton(TaskGroup);
942 }
943 else
944 {
945 /* Expand the group of one task button to a task button */
946 ExpandTaskGroup(TaskGroup);
947 }
948 }
949 }
950 }
951
953 {
954 PTASK_ITEM TaskItem, LastItem;
955
956 TaskItem = m_TaskItems;
957 LastItem = TaskItem + m_TaskItemCount;
958 while (TaskItem != LastItem)
959 {
960 if (TaskItem->hWnd == hWnd)
961 return TaskItem;
962
963 TaskItem++;
964 }
965
966 return NULL;
967 }
968
970 {
971 PTASK_ITEM LastItem, TaskItem;
972 PTASK_GROUP TaskGroup;
974
976 {
977 return NULL;
978 }
979
980 /* Try to find another task that belongs to the same
981 process as the given window */
982 TaskItem = m_TaskItems;
983 LastItem = TaskItem + m_TaskItemCount;
984 while (TaskItem != LastItem)
985 {
986 TaskGroup = TaskItem->Group;
987 if (TaskGroup != NULL)
988 {
989 if (TaskGroup->dwProcessId == dwProcessId)
990 return TaskItem;
991 }
992 else
993 {
994 DWORD dwProcessIdTask;
995
996 if (GetWindowThreadProcessId(TaskItem->hWnd,
997 &dwProcessIdTask) &&
998 dwProcessIdTask == dwProcessId)
999 {
1000 return TaskItem;
1001 }
1002 }
1003
1004 TaskItem++;
1005 }
1006
1007 return NULL;
1008 }
1009
1011 {
1013 {
1014 /* We need the most significant bit in 16 bit command IDs to indicate whether it
1015 is a task group or task item. WM_COMMAND limits command IDs to 16 bits! */
1016 return NULL;
1017 }
1018
1020
1021 if (m_TaskItemCount == 0)
1022 {
1024 0,
1026 if (m_TaskItems != NULL)
1027 {
1029 }
1030 else
1031 return NULL;
1032 }
1034 {
1035 PTASK_ITEM NewArray;
1036 SIZE_T NewArrayLength, ActiveTaskItemIndex;
1037
1039
1040 NewArray = (PTASK_ITEM) HeapReAlloc(hProcessHeap,
1041 0,
1043 NewArrayLength * sizeof(*m_TaskItems));
1044 if (NewArray != NULL)
1045 {
1046 if (m_ActiveTaskItem != NULL)
1047 {
1048 /* Fixup the ActiveTaskItem pointer */
1049 ActiveTaskItemIndex = m_ActiveTaskItem - m_TaskItems;
1050 m_ActiveTaskItem = NewArray + ActiveTaskItemIndex;
1051 }
1052 m_AllocatedTaskItems = (WORD) NewArrayLength;
1053 m_TaskItems = NewArray;
1054 }
1055 else
1056 return NULL;
1057 }
1058
1059 return m_TaskItems + m_TaskItemCount++;
1060 }
1061
1063 {
1064 WORD wIndex;
1065
1066 if (TaskItem == m_ActiveTaskItem)
1068
1069 wIndex = (WORD) (TaskItem - m_TaskItems);
1070 if (wIndex + 1 < m_TaskItemCount)
1071 {
1072 MoveMemory(TaskItem,
1073 TaskItem + 1,
1074 (m_TaskItemCount - wIndex - 1) * sizeof(*TaskItem));
1075 }
1076
1078 }
1079
1081 {
1082 if (!m_IsDestroying)
1083 {
1084 /* Delete the task button from the toolbar */
1085 DeleteTaskItemButton(TaskItem);
1086 }
1087
1088 /* Remove the task from it's group */
1089 RemoveTaskFromTaskGroup(TaskItem);
1090
1091 /* Free the task item */
1092 FreeTaskItem(TaskItem);
1093 }
1094
1096 {
1097 PTASK_ITEM CurrentTaskItem;
1098 PTASK_GROUP TaskGroup = NULL;
1099
1100 CurrentTaskItem = m_ActiveTaskItem;
1101
1102 if (TaskItem != NULL)
1103 TaskGroup = TaskItem->Group;
1104
1105 if (m_IsGroupingEnabled &&
1106 TaskGroup != NULL &&
1107 TaskGroup->IsCollapsed)
1108 {
1109 /* FIXME */
1110 return;
1111 }
1112
1113 if (CurrentTaskItem != NULL)
1114 {
1115 PTASK_GROUP CurrentTaskGroup;
1116
1117 if (CurrentTaskItem == TaskItem)
1118 return;
1119
1120 CurrentTaskGroup = CurrentTaskItem->Group;
1121
1122 if (m_IsGroupingEnabled &&
1123 CurrentTaskGroup != NULL &&
1124 CurrentTaskGroup->IsCollapsed)
1125 {
1126 if (CurrentTaskGroup == TaskGroup)
1127 return;
1128
1129 /* FIXME */
1130 }
1131 else
1132 {
1134 if (CurrentTaskItem->Index >= 0)
1135 {
1136 UpdateTaskItemButton(CurrentTaskItem);
1137 }
1138 }
1139 }
1140
1141 m_ActiveTaskItem = TaskItem;
1142
1143 if (TaskItem != NULL && TaskItem->Index >= 0)
1144 {
1145 UpdateTaskItemButton(TaskItem);
1146 }
1147 else if (TaskItem == NULL)
1148 {
1149 TRACE("Active TaskItem now NULL\n");
1150 }
1151 }
1152
1154 {
1155 PTASK_ITEM TaskItem, LastItem;
1156
1157 TaskItem = m_TaskItems;
1158 LastItem = TaskItem + m_TaskItemCount;
1159 while (TaskItem != LastItem)
1160 {
1161 if (TaskItem->Index == Index)
1162 return TaskItem;
1163
1164 TaskItem++;
1165 }
1166
1167 return NULL;
1168 }
1169
1171 {
1172 PTASK_GROUP CurrentGroup;
1173
1174 CurrentGroup = m_TaskGroups;
1175 while (CurrentGroup != NULL)
1176 {
1177 if (CurrentGroup->Index == Index)
1178 break;
1179
1180 CurrentGroup = CurrentGroup->Next;
1181 }
1182
1183 return CurrentGroup;
1184 }
1185
1187 {
1188 PTASK_ITEM TaskItem;
1189
1190 if (!::IsWindow(hWnd) || m_Tray->IsSpecialHWND(hWnd))
1191 return FALSE;
1192
1193 TaskItem = FindTaskItem(hWnd);
1194 if (TaskItem == NULL)
1195 {
1196 TRACE("Add window 0x%p\n", hWnd);
1197 TaskItem = AllocTaskItem();
1198 if (TaskItem != NULL)
1199 {
1200 ZeroMemory(TaskItem, sizeof(*TaskItem));
1201 TaskItem->hWnd = hWnd;
1202 TaskItem->Index = -1;
1203 TaskItem->Group = AddToTaskGroup(hWnd);
1204
1205 if (!m_IsDestroying)
1206 {
1207 AddTaskItemButton(TaskItem);
1208 }
1209 }
1210 }
1211
1212 return TaskItem != NULL;
1213 }
1214
1216 {
1217 if (TaskItem != NULL)
1218 {
1219 TRACE("Activate window 0x%p on button %d\n", TaskItem->hWnd, TaskItem->Index);
1220 }
1221
1222 CheckActivateTaskItem(TaskItem);
1223 return FALSE;
1224 }
1225
1227 {
1228 PTASK_ITEM TaskItem;
1229
1230 if (!hWnd)
1231 {
1232 return ActivateTaskItem(NULL);
1233 }
1234
1235 TaskItem = FindTaskItem(hWnd);
1236 if (TaskItem == NULL)
1237 {
1238 TaskItem = FindOtherTaskItem(hWnd);
1239 }
1240
1241 if (TaskItem == NULL)
1242 {
1243 WARN("Activate window 0x%p, could not find task\n", hWnd);
1245 }
1246
1247 return ActivateTaskItem(TaskItem);
1248 }
1249
1251 {
1252 PTASK_ITEM TaskItem;
1253
1254 TaskItem = FindTaskItem(hWnd);
1255 if (TaskItem != NULL)
1256 {
1257 TRACE("Delete window 0x%p on button %d\n", hWnd, TaskItem->Index);
1258 DeleteTaskItem(TaskItem);
1259 return TRUE;
1260 }
1261 //else
1262 //TRACE("Failed to delete window 0x%p\n", hWnd);
1263
1264 return FALSE;
1265 }
1266
1268 {
1269 PTASK_ITEM CurrentTask;
1270
1271 if (m_TaskItemCount > 0)
1272 {
1273 CurrentTask = m_TaskItems + m_TaskItemCount;
1274 do
1275 {
1276 DeleteTaskItem(--CurrentTask);
1277 } while (CurrentTask != m_TaskItems);
1278 }
1279 }
1280
1282 {
1283 TaskItem->RenderFlashed = 1;
1284 UpdateTaskItemButton(TaskItem);
1285 }
1286
1288 {
1289 PTASK_ITEM TaskItem;
1290
1291 TaskItem = FindTaskItem(hWnd);
1292 if (TaskItem != NULL)
1293 {
1294 TRACE("Flashing window 0x%p on button %d\n", hWnd, TaskItem->Index);
1295 FlashTaskItem(TaskItem);
1296 return TRUE;
1297 }
1298
1299 return FALSE;
1300 }
1301
1303 {
1304 PTASK_GROUP TaskGroup;
1305
1306 TaskGroup = TaskItem->Group;
1307 if (m_IsGroupingEnabled && TaskGroup != NULL)
1308 {
1309 if (TaskGroup->IsCollapsed && TaskGroup->Index >= 0)
1310 {
1311 UpdateTaskGroupButton(TaskGroup);
1312 }
1313 else if (TaskItem->Index >= 0)
1314 {
1315 goto UpdateTaskItem;
1316 }
1317 }
1318 else if (TaskItem->Index >= 0)
1319 {
1320 UpdateTaskItem:
1321 TaskItem->RenderFlashed = 0;
1322 UpdateTaskItemButton(TaskItem);
1323 }
1324 }
1325
1326
1328 {
1329 PTASK_ITEM TaskItem;
1330
1331 TaskItem = FindTaskItem(hWnd);
1332 if (TaskItem != NULL)
1333 {
1334 RedrawTaskItem(TaskItem);
1335 return TRUE;
1336 }
1337
1338 return FALSE;
1339 }
1340
1342 {
1343 RECT rcClient;
1344 UINT uiRows, uiMax, uiMin, uiBtnsPerLine, ui;
1345 LONG NewBtnSize;
1346 BOOL Horizontal;
1347
1348 /* Update the size of the image list if needed */
1349 int cx, cy;
1353 {
1357
1358 /* SetIconSize removes all icons so we have to reinsert them */
1359 PTASK_ITEM TaskItem = m_TaskItems;
1360 PTASK_ITEM LastTaskItem = m_TaskItems + m_TaskItemCount;
1361 while (TaskItem != LastTaskItem)
1362 {
1363 TaskItem->IconIndex = -1;
1364 UpdateTaskItemButton(TaskItem);
1365
1366 TaskItem++;
1367 }
1368 m_TaskBar.SetImageList(m_ImageList);
1369 }
1370
1371 if (GetClientRect(&rcClient) && !IsRectEmpty(&rcClient))
1372 {
1373 if (m_ButtonCount > 0)
1374 {
1375 Horizontal = m_Tray->IsHorizontal();
1376
1377 if (Horizontal)
1378 {
1379 TBMETRICS tbm = { 0 };
1380 tbm.cbSize = sizeof(tbm);
1382 m_TaskBar.GetMetrics(&tbm);
1383
1384 if (m_ButtonSize.cy + tbm.cyButtonSpacing != 0)
1385 uiRows = (rcClient.bottom + tbm.cyButtonSpacing) / (m_ButtonSize.cy + tbm.cyButtonSpacing);
1386 else
1387 uiRows = 1;
1388
1389 if (uiRows == 0)
1390 uiRows = 1;
1391
1392 uiBtnsPerLine = (m_ButtonCount + uiRows - 1) / uiRows;
1393 }
1394 else
1395 {
1396 uiBtnsPerLine = 1;
1397 uiRows = m_ButtonCount;
1398 }
1399
1400 if (!bRedrawDisabled)
1402
1403 /* We might need to update the button spacing */
1404 int cxButtonSpacing = m_TaskBar.UpdateTbButtonSpacing(
1405 Horizontal, m_Theme != NULL,
1406 uiRows, uiBtnsPerLine);
1407
1408 /* Determine the minimum and maximum width of a button */
1410 if (Horizontal)
1411 {
1413
1414 /* Calculate the ideal width and make sure it's within the allowed range */
1415 NewBtnSize = (rcClient.right - (uiBtnsPerLine * cxButtonSpacing)) / uiBtnsPerLine;
1416
1417 if (NewBtnSize < (LONG) uiMin)
1418 NewBtnSize = uiMin;
1419 if (NewBtnSize >(LONG)uiMax)
1420 NewBtnSize = uiMax;
1421
1422 /* Recalculate how many buttons actually fit into one line */
1423 uiBtnsPerLine = rcClient.right / (NewBtnSize + cxButtonSpacing);
1424 if (uiBtnsPerLine == 0)
1425 uiBtnsPerLine++;
1426 }
1427 else
1428 {
1429 NewBtnSize = uiMax = rcClient.right;
1430 }
1431
1432 m_ButtonSize.cx = NewBtnSize;
1433
1434 m_ButtonsPerLine = uiBtnsPerLine;
1435
1436 for (ui = 0; ui != m_ButtonCount; ui++)
1437 {
1438 TBBUTTONINFOW tbbi = { 0 };
1439 tbbi.cbSize = sizeof(tbbi);
1441 tbbi.cx = (INT) NewBtnSize;
1442 tbbi.fsState = TBSTATE_ENABLED;
1443
1444 /* Check if we're updating a button that is the last one in the
1445 line. If so, we need to set the TBSTATE_WRAP flag! */
1446 if (Horizontal)
1447 {
1448 if ((ui + 1) % uiBtnsPerLine == 0)
1449 tbbi.fsState |= TBSTATE_WRAP;
1450 }
1451 else
1452 {
1453 tbbi.fsState |= TBSTATE_WRAP;
1454 }
1455
1456 if (m_ActiveTaskItem != NULL &&
1458 {
1459 tbbi.fsState |= TBSTATE_CHECKED;
1460 }
1461
1462 m_TaskBar.SetButtonInfo(ui, &tbbi);
1463 }
1464 }
1465 else
1466 {
1467 m_ButtonsPerLine = 0;
1468 m_ButtonSize.cx = 0;
1469 }
1470 }
1471
1472 // FIXME: This seems to be enabling redraws prematurely, but moving it to its right place doesn't work!
1474 }
1475
1477 {
1478 if (m_Tray->IsTaskWnd(hWnd))
1479 {
1480 TRACE("Adding task for %p...\n", hWnd);
1481 AddTask(hWnd);
1482 }
1483 return TRUE;
1484 }
1485
1487 {
1489
1490 return This->EnumWindowsProc(hWnd);
1491 }
1492
1494 {
1495 TRACE("Refreshing window list...\n");
1496 /* Add all windows to the toolbar */
1497 return EnumWindows(s_EnumWindowsProc, (LPARAM)this);
1498 }
1499
1501 {
1502 TRACE("OmThemeChanged\n");
1503
1504 if (m_Theme)
1506
1507 if (IsThemeActive())
1508 m_Theme = OpenThemeData(m_hWnd, L"TaskBand");
1509 else
1510 m_Theme = NULL;
1511
1512 return TRUE;
1513 }
1514
1516 {
1518 return FALSE;
1519
1520 SetWindowTheme(m_TaskBar.m_hWnd, L"TaskBand", NULL);
1521
1524 ILC_COLOR32 | ILC_MASK, 0, 1000);
1525 m_TaskBar.SetImageList(m_ImageList);
1526
1527 /* Set proper spacing between buttons */
1528 m_TaskBar.UpdateTbButtonSpacing(m_Tray->IsHorizontal(), m_Theme != NULL);
1529
1530 /* Register the shell hook */
1532
1533 TRACE("ShellHookMsg got assigned number %d\n", m_ShellHookMsg);
1534
1535 RegisterShellHook(m_hWnd, 3); /* 1 if no NT! We're targeting NT so we don't care! */
1536
1538
1539 /* Recalculate the button size */
1541
1542#if DUMP_TASKS != 0
1543 SetTimer(hwnd, 1, 5000, NULL);
1544#endif
1545 return TRUE;
1546 }
1547
1549 {
1551
1553
1554 /* Unregister the shell hook */
1556
1559
1560 if (m_ImageList)
1561 {
1563 m_ImageList = NULL;
1564 }
1565
1566 return TRUE;
1567 }
1568
1570 {
1571 BOOL bResult = FALSE;
1572 WCHAR szBuf[MAX_PATH * 2];
1573 wsprintfW(szBuf, L"%s\\AppKey\\%u", REGSTR_PATH_EXPLORER, uAppCmd);
1574 HUSKEY hKey;
1576 return bResult;
1577
1578 DWORD cb = sizeof(szBuf);
1579 if (!bResult && SHRegQueryUSValueW(hKey, L"ShellExecute", NULL, szBuf, &cb, FALSE, NULL, 0) == ERROR_SUCCESS)
1580 {
1581 bResult = TRUE;
1582 }
1583 cb = sizeof(szBuf);
1584 if (!bResult && SHRegQueryUSValueW(hKey, L"Association", NULL, szBuf, &cb, FALSE, NULL, 0) == ERROR_SUCCESS)
1585 {
1586 bResult = TRUE;
1587 cb = _countof(szBuf);
1589 *szBuf = UNICODE_NULL;
1590 }
1591 cb = sizeof(szBuf);
1592 if (!bResult && SHRegQueryUSValueW(hKey, L"RegisteredApp", NULL, szBuf, &cb, FALSE, NULL, 0) == ERROR_SUCCESS)
1593 {
1594 bResult = TRUE;
1596 *szBuf = UNICODE_NULL; // Don't execute again
1597 }
1599
1600 // Note: Tweak UI uses an empty string for its "Do nothing" option.
1601 if (bResult && *szBuf)
1603 return bResult;
1604 }
1605
1607 {
1608 const UINT uAppCmd = GET_APPCOMMAND_LPARAM(lParam);
1609 if (InvokeRegistryAppKeyCommand(uAppCmd))
1610 return TRUE;
1611 switch (uAppCmd)
1612 {
1613 case APPCOMMAND_VOLUME_MUTE:
1614 case APPCOMMAND_VOLUME_DOWN:
1615 case APPCOMMAND_VOLUME_UP:
1616 // TODO: Try IMMDeviceEnumerator::GetDefaultAudioEndpoint first and then fall back to mixer.
1617 FIXME("Call the mixer API to change the global volume\n");
1618 return TRUE;
1619 case APPCOMMAND_BROWSER_SEARCH:
1620 return SHFindFiles(NULL, NULL);
1621 }
1622 return FALSE;
1623 }
1624
1626 {
1627 BOOL Ret = FALSE;
1628
1629 /* In case the shell hook wasn't registered properly, ignore WM_NULLs*/
1630 if (uMsg == 0)
1631 {
1632 bHandled = FALSE;
1633 return 0;
1634 }
1635
1636 TRACE("Received shell hook message: wParam=%08lx, lParam=%08lx\n", wParam, lParam);
1637
1638 switch ((INT) wParam)
1639 {
1640 case HSHELL_APPCOMMAND:
1641 Ret = HandleAppCommand(0, lParam);
1642 break;
1643
1645 AddTask((HWND) lParam);
1646 break;
1647
1649 /* The window still exists! Delay destroying it a bit */
1652 break;
1653
1655 case HSHELL_WINDOWACTIVATED:
1658 break;
1659
1660 case HSHELL_FLASH:
1662 break;
1663
1664 case HSHELL_REDRAW:
1666 break;
1667
1668 case HSHELL_TASKMAN:
1669 ::PostMessage(m_Tray->GetHWND(), TWM_OPENSTARTMENU, 0, 0);
1670 break;
1671
1673 ::SwitchToThisWindow(m_Tray->GetHWND(), TRUE);
1674 ::SetForegroundWindow(m_Tray->GetHWND());
1675 break;
1676
1677 case HSHELL_LANGUAGE:
1678 case HSHELL_SYSMENU:
1679 case HSHELL_ENDTASK:
1680 case HSHELL_ACCESSIBILITYSTATE:
1681 case HSHELL_WINDOWREPLACED:
1682 case HSHELL_WINDOWREPLACING:
1683
1684 case HSHELL_GETMINRECT:
1685 default:
1686 {
1687#if DEBUG_SHELL_HOOK
1688 int i, found;
1689 for (i = 0, found = 0; i != _countof(hshell_msg); i++)
1690 {
1691 if (hshell_msg[i].msg == (INT) wParam)
1692 {
1693 TRACE("Shell message %ws unhandled (lParam = 0x%p)!\n", hshell_msg[i].msg_name, lParam);
1694 found = 1;
1695 break;
1696 }
1697 }
1698 if (found)
1699 break;
1700#endif
1701 TRACE("Shell message %d unhandled (lParam = 0x%p)!\n", (INT) wParam, lParam);
1702 break;
1703 }
1704 }
1705
1706 return Ret;
1707 }
1708
1710 {
1711 BOOL bIsMinimized;
1712 BOOL bIsActive;
1713
1714 if (::IsWindow(TaskItem->hWnd))
1715 {
1716 bIsMinimized = ::IsIconic(TaskItem->hWnd);
1717 bIsActive = (TaskItem == m_ActiveTaskItem);
1718
1719 TRACE("Active TaskItem %p, selected TaskItem %p\n", m_ActiveTaskItem, TaskItem);
1720 if (m_ActiveTaskItem)
1721 TRACE("Active TaskItem hWnd=%p, TaskItem hWnd %p\n", m_ActiveTaskItem->hWnd, TaskItem->hWnd);
1722
1723 TRACE("Valid button clicked. HWND=%p, IsMinimized=%s, IsActive=%s...\n",
1724 TaskItem->hWnd, bIsMinimized ? "Yes" : "No", bIsActive ? "Yes" : "No");
1725
1726 if (!bIsMinimized && bIsActive)
1727 {
1728 if (!::IsHungAppWindow(TaskItem->hWnd))
1729 ::ShowWindowAsync(TaskItem->hWnd, SW_MINIMIZE);
1730 TRACE("Valid button clicked. App window Minimized.\n");
1731 }
1732 else
1733 {
1734 ::SwitchToThisWindow(TaskItem->hWnd, TRUE);
1735
1736 TRACE("Valid button clicked. App window Restored.\n");
1737 }
1738 }
1739 }
1740
1742 {
1743 /* TODO: Show task group menu */
1744 }
1745
1747 {
1748 PTASK_ITEM TaskItem;
1749 PTASK_GROUP TaskGroup;
1750
1752 {
1753 TaskGroup = FindTaskGroupByIndex((INT) wIndex);
1754 if (TaskGroup != NULL && TaskGroup->IsCollapsed)
1755 {
1756 HandleTaskGroupClick(TaskGroup);
1757 return TRUE;
1758 }
1759 }
1760
1761 TaskItem = FindTaskItemByIndex((INT) wIndex);
1762 if (TaskItem != NULL)
1763 {
1764 HandleTaskItemClick(TaskItem);
1765 return TRUE;
1766 }
1767
1768 return FALSE;
1769 }
1770
1771 static VOID CALLBACK
1773 {
1774 ::PostMessageW(hwnd, WM_NULL, 0, 0);
1775 }
1776
1778 {
1779 POINT pt;
1780 GetCursorPos(&pt);
1781
1782 SetForegroundWindow(TaskItem->hWnd);
1783
1784 ActivateTask(TaskItem->hWnd);
1785
1786 if (GetForegroundWindow() != TaskItem->hWnd)
1787 ERR("HandleTaskItemRightClick detected the window did not become foreground\n");
1788
1789 ::SendMessageCallbackW(TaskItem->hWnd, WM_POPUPSYSTEMMENU, 0, MAKELPARAM(pt.x, pt.y),
1790 SendAsyncProc, (ULONG_PTR)TaskItem);
1791 }
1792
1794 {
1795 /* TODO: Show task group right click menu */
1796 }
1797
1799 {
1800 PTASK_ITEM TaskItem;
1801 PTASK_GROUP TaskGroup;
1803 {
1804 TaskGroup = FindTaskGroupByIndex((INT) wIndex);
1805 if (TaskGroup != NULL && TaskGroup->IsCollapsed)
1806 {
1807 HandleTaskGroupRightClick(TaskGroup);
1808 return TRUE;
1809 }
1810 }
1811
1812 TaskItem = FindTaskItemByIndex((INT) wIndex);
1813
1814 if (TaskItem != NULL)
1815 {
1816 HandleTaskItemRightClick(TaskItem);
1817 return TRUE;
1818 }
1819
1820 return FALSE;
1821 }
1822
1823
1825 {
1826 LRESULT Ret = CDRF_DODEFAULT;
1827 PTASK_GROUP TaskGroup;
1828 PTASK_ITEM TaskItem;
1829
1830 TaskItem = FindTaskItemByIndex((INT) nmtbcd->nmcd.dwItemSpec);
1831 TaskGroup = FindTaskGroupByIndex((INT) nmtbcd->nmcd.dwItemSpec);
1832 if (TaskGroup == NULL && TaskItem != NULL)
1833 {
1834 ASSERT(TaskItem != NULL);
1835
1836 if (TaskItem != NULL && ::IsWindow(TaskItem->hWnd))
1837 {
1838 /* Make the entire button flashing if necessary */
1839 if (nmtbcd->nmcd.uItemState & CDIS_MARKED)
1840 {
1841 Ret = TBCDRF_NOBACKGROUND;
1842 if (!m_Theme)
1843 {
1844 SelectObject(nmtbcd->nmcd.hdc, GetSysColorBrush(COLOR_HIGHLIGHT));
1845 Rectangle(nmtbcd->nmcd.hdc,
1846 nmtbcd->nmcd.rc.left,
1847 nmtbcd->nmcd.rc.top,
1848 nmtbcd->nmcd.rc.right,
1849 nmtbcd->nmcd.rc.bottom);
1850 }
1851 else
1852 {
1853 DrawThemeBackground(m_Theme, nmtbcd->nmcd.hdc, TDP_FLASHBUTTON, 0, &nmtbcd->nmcd.rc, 0);
1854 }
1855 nmtbcd->clrText = GetSysColor(COLOR_HIGHLIGHTTEXT);
1856 return Ret;
1857 }
1858 }
1859 }
1860 else if (TaskGroup != NULL)
1861 {
1862 /* FIXME: Implement painting for task groups */
1863 }
1864 return Ret;
1865 }
1866
1868 {
1869 LRESULT Ret = 0;
1870
1871 switch (nmh->code)
1872 {
1873 case NM_CUSTOMDRAW:
1874 {
1875 LPNMTBCUSTOMDRAW nmtbcd = (LPNMTBCUSTOMDRAW) nmh;
1876
1877 switch (nmtbcd->nmcd.dwDrawStage)
1878 {
1879
1880 case CDDS_ITEMPREPAINT:
1881 Ret = HandleItemPaint(nmtbcd);
1882 break;
1883
1884 case CDDS_PREPAINT:
1885 Ret = CDRF_NOTIFYITEMDRAW;
1886 break;
1887
1888 default:
1889 Ret = CDRF_DODEFAULT;
1890 break;
1891 }
1892 break;
1893 }
1894 }
1895
1896 return Ret;
1897 }
1898
1899 // Internal structure for IsRudeEnumProc
1900 typedef struct tagRUDEAPPDATA
1901 {
1906
1907 // Find any rude app
1908 static BOOL CALLBACK
1910 {
1912
1913 HMONITOR hMon = ::MonitorFromWindow(hwnd, MONITOR_DEFAULTTONEAREST);
1914 if (!hMon ||
1915 (pData->hTargetMonitor && pData->hTargetMonitor != hMon) ||
1916 !SHELL_IsRudeWindow(hMon, hwnd, (hwnd == pData->hwndFirstCheck)))
1917 {
1918 return TRUE; // Continue
1919 }
1920
1921 pData->hwndFound = hwnd;
1922 return FALSE; // Finish
1923 }
1924
1925 // Internal structure for FullScreenEnumProc
1926 typedef struct tagFULLSCREENDATA
1927 {
1928 const RECT *pRect;
1930 ITrayWindow *pTray;
1932
1933 // Notify ABN_FULLSCREENAPP for each monitor
1934 static BOOL CALLBACK
1936 {
1938
1939 BOOL bFullOpening = (pData->hTargetMonitor == hMonitor);
1940 if (!bFullOpening && pData->pRect)
1941 {
1942 RECT rc, rcMon;
1943 SHELL_GetMonitorRect(hMonitor, &rcMon, FALSE);
1944 ::IntersectRect(&rc, &rcMon, pData->pRect);
1945 bFullOpening = ::EqualRect(&rc, &rcMon);
1946 }
1947
1948 // Notify ABN_FULLSCREENAPP to appbars
1949 pData->pTray->NotifyFullScreenToAppBars(hMonitor, bFullOpening);
1950 return TRUE;
1951 }
1952
1954 {
1955 // Notify ABN_FULLSCREENAPP for every monitor
1956 RECT rc;
1958 if (hwndRude && ::GetWindowRect(hwndRude, &rc))
1959 {
1960 Data.pRect = &rc;
1961 Data.hTargetMonitor = ::MonitorFromWindow(hwndRude, MONITOR_DEFAULTTONULL);
1962 }
1963 Data.pTray = m_Tray;
1965
1966 if (hwndRude)
1967 {
1968 // Make the taskbar bottom
1970 HWND hwndTray = m_Tray->GetHWND();
1971 ::SetWindowPos(hwndTray, HWND_BOTTOM, 0, 0, 0, 0, uFlags);
1972
1973 // Switch to the rude app if necessary
1974 DWORD exstyle = (DWORD)::GetWindowLongPtrW(hwndRude, GWL_EXSTYLE);
1975 if (!(exstyle & WS_EX_TOPMOST) && !SHELL_IsRudeWindowActive(hwndRude))
1976 ::SwitchToThisWindow(hwndRude, TRUE);
1977 }
1978 }
1979
1981 {
1982 // Quick check
1983 HMONITOR hMon = MonitorFromWindow(hwndFirstCheck, MONITOR_DEFAULTTONEAREST);
1984 RUDEAPPDATA data = { hMon, NULL, hwndFirstCheck };
1985 if (::IsWindow(hwndFirstCheck) && !IsRudeEnumProc(hwndFirstCheck, (LPARAM)&data))
1986 return hwndFirstCheck;
1987
1988 // Slow check
1990
1991 return data.hwndFound;
1992 }
1993
1994 // WM_WINDOWPOSCHANGED
1996 {
1997 // Re-start rude app validation
2001 bHandled = FALSE;
2002 return 0;
2003 }
2004
2005 // HSHELL_WINDOWACTIVATED, HSHELL_RUDEAPPACTIVATED
2006 void OnWindowActivated(_In_ HWND hwndTarget)
2007 {
2008 // Re-start rude app validation
2012 }
2013
2014 // HSHELL_WINDOWDESTROYED
2015 void OnWindowDestroyed(_In_ HWND hwndTarget)
2016 {
2017 if (!FindTaskItem(hwndTarget))
2018 return;
2019 HWND hwndRude = FindRudeApp(hwndTarget);
2020 HandleFullScreenApp(hwndRude);
2021 }
2022
2024 {
2025 HDC hdc = (HDC) wParam;
2026
2027 if (!IsAppThemed())
2028 {
2029 bHandled = FALSE;
2030 return 0;
2031 }
2032
2033 RECT rect;
2036
2037 return TRUE;
2038 }
2039
2041 {
2042 SIZE szClient;
2043
2044 szClient.cx = LOWORD(lParam);
2045 szClient.cy = HIWORD(lParam);
2046 if (m_TaskBar.m_hWnd != NULL)
2047 {
2048 m_TaskBar.SetWindowPos(NULL, 0, 0, szClient.cx, szClient.cy, SWP_NOZORDER);
2049
2051 }
2052 return TRUE;
2053 }
2054
2056 {
2057 LRESULT Ret = TRUE;
2058 /* We want the tray window to be draggable everywhere, so make the control
2059 appear transparent */
2060 Ret = DefWindowProc(uMsg, wParam, lParam);
2061 if (Ret != HTVSCROLL && Ret != HTHSCROLL)
2062 Ret = HTTRANSPARENT;
2063 return Ret;
2064 }
2065
2067 {
2068 LRESULT Ret = TRUE;
2069 if (lParam != 0 && (HWND) lParam == m_TaskBar.m_hWnd)
2070 {
2072 }
2073 return Ret;
2074 }
2075
2077 {
2078 LRESULT Ret = TRUE;
2079 const NMHDR *nmh = (const NMHDR *) lParam;
2080
2081 if (nmh->hwndFrom == m_TaskBar.m_hWnd)
2082 {
2083 Ret = HandleToolbarNotification(nmh);
2084 }
2085 return Ret;
2086 }
2087
2089 {
2090 /* Update the button spacing */
2091 m_TaskBar.UpdateTbButtonSpacing(m_Tray->IsHorizontal(), m_Theme != NULL);
2092 return TRUE;
2093 }
2094
2096 {
2097 BOOL bSettingsChanged = FALSE;
2098 TaskbarSettings* newSettings = (TaskbarSettings*)lParam;
2099
2100 if (newSettings->bGroupButtons != g_TaskbarSettings.bGroupButtons)
2101 {
2102 bSettingsChanged = TRUE;
2105 }
2106
2107 if (newSettings->bSmallIcons != g_TaskbarSettings.bSmallIcons)
2108 {
2109 bSettingsChanged = TRUE;
2111 }
2112
2113 if (bSettingsChanged)
2114 {
2115 /* Refresh each task item view */
2118 }
2119
2120 return 0;
2121 }
2122
2124 {
2125 LRESULT Ret = 0;
2126 INT_PTR iBtn = -1;
2127
2128 if (m_TaskBar.m_hWnd != NULL)
2129 {
2130 POINT pt;
2131
2132 pt.x = GET_X_LPARAM(lParam);
2133 pt.y = GET_Y_LPARAM(lParam);
2134
2136
2137 iBtn = m_TaskBar.HitTest(&pt);
2138 if (iBtn >= 0)
2139 {
2141 }
2142 }
2143 if (iBtn < 0)
2144 {
2145 /* Not on a taskbar button, so forward message to tray */
2146 Ret = SendMessage(m_Tray->GetHWND(), uMsg, wParam, lParam);
2147 }
2148 return Ret;
2149 }
2150
2152 {
2153 PTASK_ITEM TaskItem = FindTaskItem((HWND) wParam);
2154 if (TaskItem)
2155 {
2156 RECT* prcMinRect = (RECT*) lParam;
2157 RECT rcItem, rcToolbar;
2158 m_TaskBar.GetItemRect(TaskItem->Index, &rcItem);
2159 m_TaskBar.GetWindowRect(&rcToolbar);
2160
2161 OffsetRect(&rcItem, rcToolbar.left, rcToolbar.top);
2162
2163 *prcMinRect = rcItem;
2164 return TRUE;
2165 }
2166 return FALSE;
2167 }
2168
2170 {
2171 return MA_NOACTIVATE;
2172 }
2173
2175 {
2176 switch (wParam)
2177 {
2178#if DUMP_TASKS != 0
2179 case 1:
2180 DumpTasks();
2181 break;
2182#endif
2184 {
2185 // Real activation of rude app might take some time after HSHELL_...ACTIVATED.
2186 // Wait up to 5 seconds with validating the rude app at each second.
2187 HWND hwndRude = FindRudeApp(NULL);
2188 HandleFullScreenApp(hwndRude);
2189
2194 break;
2195 }
2196 default:
2197 {
2198 WARN("Unknown timer ID: %p\n", wParam);
2199 break;
2200 }
2201 }
2202 return TRUE;
2203 }
2204
2206 {
2207 return m_TaskBar.SendMessageW(uMsg, wParam, lParam);
2208 }
2209
2211 {
2212 if (wParam == SPI_SETNONCLIENTMETRICS)
2213 {
2214 /* Don't update the font, this will be done when we get a WM_SETFONT from our parent */
2216 }
2217
2218 return 0;
2219 }
2220
2222 {
2224 if (cpData->dwData == m_uHardErrorMsg)
2225 {
2226 /* A hard error balloon message */
2228 ERR("Got balloon data 0x%x, 0x%x, '%S', '%S'\n", pData->Status, pData->dwType, (WCHAR*)((ULONG_PTR)pData + pData->TitleOffset), (WCHAR*)((ULONG_PTR)pData + pData->MessageOffset));
2229 if (pData->cbHeaderSize == sizeof(BALLOON_HARD_ERROR_DATA))
2231 return TRUE;
2232 }
2233
2234 return FALSE;
2235 }
2236
2238 {
2239 m_Tray = tray;
2242 if (!m_hWnd)
2243 return E_FAIL;
2244 return S_OK;
2245 }
2246
2247 // *** IOleWindow methods ***
2248
2250 GetWindow(HWND* phwnd) override
2251 {
2252 if (!phwnd)
2253 return E_INVALIDARG;
2254 *phwnd = m_hWnd;
2255 return S_OK;
2256 }
2257
2259 ContextSensitiveHelp(BOOL fEnterMode) override
2260 {
2261 return E_NOTIMPL;
2262 }
2263
2265
2267 MESSAGE_HANDLER(WM_THEMECHANGED, OnThemeChanged)
2286 END_MSG_MAP()
2287
2289
2293 END_COM_MAP()
2294};
2295
2297{
2298 return ShellObjectCreatorInit<CTaskSwitchWnd>(hWndParent, Tray, riid, ppv);
2299}
static HDC hDC
Definition: 3dtext.c:33
Arabic default style
Definition: afstyles.h:94
WCHAR windowText[1024]
Definition: appswitch.c:48
#define InterlockedExchange
Definition: armddk.h:54
#define msg(x)
Definition: auth_time.c:54
HWND hWnd
Definition: settings.c:17
@ Create
Definition: registry.c:563
#define FIXME(fmt,...)
Definition: precomp.h:53
#define WARN(fmt,...)
Definition: precomp.h:61
#define ERR(fmt,...)
Definition: precomp.h:57
HANDLE hProcessHeap
Definition: explorer.cpp:25
#define TWM_OPENSTARTMENU
Definition: precomp.h:133
#define TSWM_UPDATETASKBARPOS
Definition: precomp.h:397
TaskbarSettings g_TaskbarSettings
Definition: settings.cpp:23
#define TWM_SETTINGSCHANGED
Definition: precomp.h:134
#define STDMETHODIMP
Definition: basetyps.h:43
BOOL IsIconic() const
Definition: atlwin.h:932
BOOL SetWindowPos(HWND hWndInsertAfter, int x, int y, int cx, int cy, UINT nFlags)
Definition: atlwin.h:1288
BOOL ScreenToClient(LPPOINT lpPoint) const
Definition: atlwin.h:1092
void SetRedraw(BOOL bRedraw=TRUE)
Definition: atlwin.h:1234
BOOL GetWindowRect(LPRECT lpRect) const
Definition: atlwin.h:816
HWND m_hWnd
Definition: atlwin.h:273
BOOL InvalidateRect(LPCRECT lpRect, BOOL bErase=TRUE)
Definition: atlwin.h:902
BOOL IsWindow() const
Definition: atlwin.h:947
CStringW m_Title
Definition: taskswnd.cpp:195
static DWORD CALLBACK s_HardErrorThreadProc(IN OUT LPVOID lpParameter)
Definition: taskswnd.cpp:253
CStringW m_Text
Definition: taskswnd.cpp:196
HRESULT ThreadProc()
Definition: taskswnd.cpp:221
void StartThread(PBALLOON_HARD_ERROR_DATA pData)
Definition: taskswnd.cpp:263
BOOL HandleAppCommand(IN WPARAM wParam, IN LPARAM lParam)
Definition: taskswnd.cpp:1606
UINT m_ShellHookMsg
Definition: taskswnd.cpp:389
static BOOL CALLBACK s_EnumWindowsProc(IN HWND hWnd, IN LPARAM lParam)
Definition: taskswnd.cpp:1486
VOID RedrawTaskItem(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:1302
LRESULT OnTaskbarSettingsChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2095
INT UpdateTaskItemButton(IN PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:611
INT GetWndTextFromTaskItem(IN PTASK_ITEM TaskItem, LPWSTR szBuf, DWORD cchBuf)
Definition: taskswnd.cpp:435
LRESULT OnNotify(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2076
LRESULT OnContextMenu(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2123
LRESULT OnTimer(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2174
PTASK_ITEM FindOtherTaskItem(IN HWND hWnd)
Definition: taskswnd.cpp:969
VOID UpdateButtonsSize(IN BOOL bRedrawDisabled)
Definition: taskswnd.cpp:1341
BOOL HandleButtonClick(IN WORD wIndex)
Definition: taskswnd.cpp:1746
virtual ~CTaskSwitchWnd()
Definition: taskswnd.cpp:433
PTASK_ITEM m_ActiveTaskItem
Definition: taskswnd.cpp:396
VOID ExpandTaskGroup(IN PTASK_GROUP TaskGroup)
Definition: taskswnd.cpp:567
PTASK_ITEM m_TaskItems
Definition: taskswnd.cpp:395
STDMETHODIMP ContextSensitiveHelp(BOOL fEnterMode) override
Definition: taskswnd.cpp:2259
PTASK_GROUP AddToTaskGroup(IN HWND hWnd)
Definition: taskswnd.cpp:862
INT m_nRudeAppValidationCounter
Definition: taskswnd.cpp:407
VOID RemoveIcon(IN PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:657
CComPtr< ITrayWindow > m_Tray
Definition: taskswnd.cpp:387
VOID CheckActivateTaskItem(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:1095
CTaskToolbar m_TaskBar
Definition: taskswnd.cpp:385
UINT m_uHardErrorMsg
Definition: taskswnd.cpp:411
VOID UpdateIndexesAfter(IN INT iIndex, BOOL bInserted)
Definition: taskswnd.cpp:495
LRESULT OnWindowPosChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:1995
BOOL m_IsDestroying
Definition: taskswnd.cpp:405
VOID FreeTaskItem(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:1062
LRESULT OnCommand(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2066
WORD m_ButtonCount
Definition: taskswnd.cpp:400
PTASK_ITEM AllocTaskItem()
Definition: taskswnd.cpp:1010
LRESULT OnSettingChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2210
static BOOL CALLBACK IsRudeEnumProc(_In_ HWND hwnd, _In_ LPARAM lParam)
Definition: taskswnd.cpp:1909
HTHEME m_Theme
Definition: taskswnd.cpp:398
CHardErrorThread m_HardErrorThread
Definition: taskswnd.cpp:412
static BOOL CALLBACK FullScreenEnumProc(_In_ HMONITOR hMonitor, _In_opt_ HDC hDC, _In_ LPRECT prc, _In_ LPARAM lParam)
Definition: taskswnd.cpp:1935
VOID FlashTaskItem(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:1281
VOID RemoveTaskFromTaskGroup(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:906
BOOL FlashTask(IN HWND hWnd)
Definition: taskswnd.cpp:1287
PTASK_ITEM FindLastTaskItemOfGroup(IN PTASK_GROUP TaskGroup OPTIONAL, IN PTASK_ITEM NewTaskItem OPTIONAL)
Definition: taskswnd.cpp:685
LRESULT OnShellHook(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:1625
struct CTaskSwitchWnd::tagRUDEAPPDATA RUDEAPPDATA
INT AddTaskItemButton(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:767
LRESULT OnMouseActivate(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2169
BOOL ActivateTask(IN HWND hWnd)
Definition: taskswnd.cpp:1226
INT UpdateTaskGroupButton(IN PTASK_GROUP TaskGroup)
Definition: taskswnd.cpp:558
VOID DeleteTaskItem(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:1080
BOOL ActivateTaskItem(IN OUT PTASK_ITEM TaskItem OPTIONAL)
Definition: taskswnd.cpp:1215
VOID DeleteAllTasks()
Definition: taskswnd.cpp:1267
BOOL RefreshWindowList()
Definition: taskswnd.cpp:1493
LRESULT OnSize(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2040
BOOL RedrawTask(IN HWND hWnd)
Definition: taskswnd.cpp:1327
PTASK_GROUP m_TaskGroups
Definition: taskswnd.cpp:394
PTASK_GROUP FindTaskGroupByIndex(IN INT Index)
Definition: taskswnd.cpp:1170
BOOL m_IsGroupingEnabled
Definition: taskswnd.cpp:404
LRESULT OnKludgeItemRect(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2151
struct CTaskSwitchWnd::tagFULLSCREENDATA FULLSCREENDATA
BOOL DeleteTaskItemButton(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:827
HICON GetWndIcon(HWND hwnd)
Definition: taskswnd.cpp:576
LRESULT OnDestroy(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:1548
static BOOL InvokeRegistryAppKeyCommand(UINT uAppCmd)
Definition: taskswnd.cpp:1569
VOID HandleTaskGroupRightClick(IN OUT PTASK_GROUP TaskGroup)
Definition: taskswnd.cpp:1793
BOOL CALLBACK EnumWindowsProc(IN HWND hWnd)
Definition: taskswnd.cpp:1476
LRESULT OnCreate(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:1515
WORD m_AllocatedTaskItems
Definition: taskswnd.cpp:392
HWND FindRudeApp(_In_opt_ HWND hwndFirstCheck)
Definition: taskswnd.cpp:1980
struct CTaskSwitchWnd::tagRUDEAPPDATA * PRUDEAPPDATA
LRESULT OnThemeChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:1500
LRESULT OnSetFont(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2205
VOID HandleTaskGroupClick(IN OUT PTASK_GROUP TaskGroup)
Definition: taskswnd.cpp:1741
void HandleFullScreenApp(_In_opt_ HWND hwndRude)
Definition: taskswnd.cpp:1953
LRESULT OnEraseBackground(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2023
PTASK_ITEM FindTaskItem(IN HWND hWnd)
Definition: taskswnd.cpp:952
LRESULT HandleItemPaint(IN OUT NMTBCUSTOMDRAW *nmtbcd)
Definition: taskswnd.cpp:1824
STDMETHODIMP GetWindow(HWND *phwnd) override
Definition: taskswnd.cpp:2250
void OnWindowDestroyed(_In_ HWND hwndTarget)
Definition: taskswnd.cpp:2015
HIMAGELIST m_ImageList
Definition: taskswnd.cpp:402
PTASK_ITEM FindTaskItemByIndex(IN INT Index)
Definition: taskswnd.cpp:1153
VOID HandleTaskItemClick(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:1709
LRESULT OnNcHitTest(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2055
static VOID CALLBACK SendAsyncProc(HWND hwnd, UINT uMsg, DWORD_PTR dwData, LRESULT lResult)
Definition: taskswnd.cpp:1772
VOID HandleTaskItemRightClick(IN OUT PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:1777
BOOL DeleteTask(IN HWND hWnd)
Definition: taskswnd.cpp:1250
HRESULT Initialize(IN HWND hWndParent, IN OUT ITrayWindow *tray)
Definition: taskswnd.cpp:2237
INT CalculateTaskItemNewButtonIndex(IN PTASK_ITEM TaskItem)
Definition: taskswnd.cpp:723
LRESULT OnUpdateTaskbarPos(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2088
WORD m_TaskItemCount
Definition: taskswnd.cpp:391
LRESULT OnCopyData(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:2221
LRESULT HandleToolbarNotification(IN const NMHDR *nmh)
Definition: taskswnd.cpp:1867
void OnWindowActivated(_In_ HWND hwndTarget)
Definition: taskswnd.cpp:2006
BOOL HandleButtonRightClick(IN WORD wIndex)
Definition: taskswnd.cpp:1798
struct CTaskSwitchWnd::tagFULLSCREENDATA * PFULLSCREENDATA
UINT m_ButtonsPerLine
Definition: taskswnd.cpp:399
BOOL AddTask(IN HWND hWnd)
Definition: taskswnd.cpp:1186
BOOL SetButtonCommandId(IN INT iButtonIndex, IN INT iCommandId)
Definition: taskswnd.cpp:330
INT UpdateTbButtonSpacing(IN BOOL bHorizontal, IN BOOL bThemed, IN UINT uiRows=0, IN UINT uiBtnsPerLine=0)
Definition: taskswnd.cpp:287
VOID BeginUpdate()
Definition: taskswnd.cpp:319
LRESULT OnNcHitTestToolbar(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled)
Definition: taskswnd.cpp:341
VOID EndUpdate()
Definition: taskswnd.cpp:324
BOOL Initialize(HWND hWndParent)
Definition: taskswnd.cpp:366
HWND Create(HWND hWndParent, DWORD dwStyles=0, DWORD dwExStyles=0)
Definition: rosctrls.h:256
WPARAM wParam
Definition: combotst.c:138
LPARAM lParam
Definition: combotst.c:139
#define WAIT_TIMEOUT
Definition: dderror.h:14
#define E_INVALIDARG
Definition: ddrawi.h:101
#define E_NOTIMPL
Definition: ddrawi.h:99
#define E_FAIL
Definition: ddrawi.h:102
#define ERROR_SUCCESS
Definition: deptool.c:10
#define NULL
Definition: types.h:112
#define TRUE
Definition: types.h:120
#define FALSE
Definition: types.h:117
UINT uFlags
Definition: api.c:59
BOOL WINAPI ImageList_SetIconSize(HIMAGELIST himl, INT cx, INT cy)
Definition: imagelist.c:3132
BOOL WINAPI ImageList_Remove(HIMAGELIST himl, INT i)
Definition: imagelist.c:2628
INT WINAPI ImageList_ReplaceIcon(HIMAGELIST himl, INT nIndex, HICON hIcon)
Definition: imagelist.c:2839
BOOL WINAPI ImageList_Destroy(HIMAGELIST himl)
Definition: imagelist.c:941
HIMAGELIST WINAPI ImageList_Create(INT cx, INT cy, UINT flags, INT cInitial, INT cGrow)
Definition: imagelist.c:814
BOOL WINAPI ImageList_GetIconSize(HIMAGELIST himl, INT *cx, INT *cy)
Definition: imagelist.c:2055
#define CloseHandle
Definition: compat.h:739
#define HeapAlloc
Definition: compat.h:733
#define HeapReAlloc
Definition: compat.h:734
#define MAX_PATH
Definition: compat.h:34
#define HeapFree(x, y, z)
Definition: compat.h:735
#define CALLBACK
Definition: compat.h:35
#define HEAP_ZERO_MEMORY
Definition: compat.h:134
HANDLE WINAPI DECLSPEC_HOTPATCH CreateThread(IN LPSECURITY_ATTRIBUTES lpThreadAttributes, IN DWORD dwStackSize, IN LPTHREAD_START_ROUTINE lpStartAddress, IN LPVOID lpParameter, IN DWORD dwCreationFlags, OUT LPDWORD lpThreadId)
Definition: thread.c:137
BOOL WINAPI TerminateThread(IN HANDLE hThread, IN DWORD dwExitCode)
Definition: thread.c:587
LONG WINAPI SHRegCloseUSKey(HUSKEY hUSKey)
Definition: registry.c:3626
LONG WINAPI SHRegQueryUSValueW(HUSKEY hUSKey, const WCHAR *value, DWORD *type, void *data, DWORD *data_len, BOOL ignore_hkcu, void *default_data, DWORD default_data_len)
Definition: registry.c:4019
LONG WINAPI SHRegOpenUSKeyW(const WCHAR *path, REGSAM access_mask, HUSKEY relative_key, HUSKEY *uskey, BOOL ignore_hkcu)
Definition: registry.c:3747
HRESULT WINAPI DECLSPEC_HOTPATCH CoCreateInstance(REFCLSID rclsid, LPUNKNOWN pUnkOuter, DWORD dwClsContext, REFIID iid, LPVOID *ppv)
Definition: compobj.c:3325
HRESULT WINAPI DECLSPEC_HOTPATCH OleInitialize(LPVOID reserved)
Definition: ole2.c:169
void WINAPI DECLSPEC_HOTPATCH OleUninitialize(void)
Definition: ole2.c:230
#define FAILED_UNEXPECTEDLY
Definition: utils.cpp:30
EXTERN_C HRESULT WINAPI SHRunIndirectRegClientCommand(_In_opt_ HWND hWnd, _In_ PCWSTR pszClientType)
Definition: utils.cpp:265
HRESULT WINAPI DrawThemeBackground(HTHEME hTheme, HDC hdc, int iPartId, int iStateId, const RECT *pRect, const RECT *pClipRect)
Definition: draw.c:128
HRESULT WINAPI DrawThemeParentBackground(HWND hwnd, HDC hdc, RECT *prc)
Definition: draw.c:72
BOOL WINAPI IsThemeActive(void)
Definition: system.c:630
HRESULT WINAPI CloseThemeData(HTHEME hTheme)
Definition: system.c:1036
HTHEME WINAPI OpenThemeData(HWND hwnd, LPCWSTR pszClassList)
Definition: system.c:890
BOOL WINAPI IsAppThemed(void)
Definition: system.c:620
#define pt(x, y)
Definition: drawing.c:79
return ret
Definition: mutex.c:146
#define L(x)
Definition: resources.c:13
#define ULONG_PTR
Definition: config.h:101
DWORD dwThreadId
Definition: fdebug.c:31
unsigned short WORD
Definition: ntddk_ex.h:93
unsigned int BOOL
Definition: ntddk_ex.h:94
unsigned long DWORD
Definition: ntddk_ex.h:95
FxAutoRegKey hKey
GLint GLenum GLsizei GLsizei GLsizei GLint GLsizei const GLvoid * data
Definition: gl.h:1950
GLintptr offset
Definition: glext.h:5920
GLuint index
Definition: glext.h:6031
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248
REFIID riid
Definition: atlbase.h:39
REFIID LPVOID * ppv
Definition: atlbase.h:39
#define S_OK
Definition: intsafe.h:52
#define BEGIN_COM_MAP(x)
Definition: atlcom.h:581
#define COM_INTERFACE_ENTRY_IID(iid, x)
Definition: atlcom.h:601
#define DECLARE_PROTECT_FINAL_CONSTRUCT()
Definition: atlcom.h:679
#define DECLARE_NOT_AGGREGATABLE(x)
Definition: atlcom.h:651
#define END_COM_MAP()
Definition: atlcom.h:592
#define MESSAGE_HANDLER(msg, func)
Definition: atlwin.h:1926
#define BEGIN_MSG_MAP(theClass)
Definition: atlwin.h:1898
#define END_MSG_MAP()
Definition: atlwin.h:1917
#define DECLARE_WND_CLASS_EX(WndClassName, style, bkgnd)
Definition: atlwin.h:2004
#define ZeroMemory
Definition: minwinbase.h:31
#define MoveMemory
Definition: minwinbase.h:28
LONG_PTR LPARAM
Definition: minwindef.h:175
LONG_PTR LRESULT
Definition: minwindef.h:176
UINT_PTR WPARAM
Definition: minwindef.h:174
#define ASSERT(a)
Definition: mode.c:44
HDC hdc
Definition: main.c:9
static HDC
Definition: imagelist.c:88
static HICON
Definition: imagelist.c:80
static HANDLE ULONG_PTR dwData
Definition: file.c:35
static HMODULE MODULEINFO DWORD cb
Definition: module.c:33
static MONITORINFO mi
Definition: win.c:7338
static HTHEME(WINAPI *pOpenThemeDataEx)(HWND
HICON hIcon
Definition: msconfig.c:44
HMONITOR WINAPI MonitorFromWindow(HWND, DWORD)
unsigned int UINT
Definition: ndis.h:50
#define _Out_opt_
Definition: no_sal2.h:214
#define _In_
Definition: no_sal2.h:158
#define _In_opt_
Definition: no_sal2.h:212
#define KEY_READ
Definition: nt_native.h:1026
#define DWORD
Definition: nt_native.h:44
#define UNICODE_NULL
_Out_ LPRECT prc
Definition: ntgdi.h:1658
UINT ui
Definition: oleauto.h:49
const GUID IID_IOleWindow
#define LOWORD(l)
Definition: pedump.c:82
#define WS_CHILD
Definition: pedump.c:617
#define WS_TABSTOP
Definition: pedump.c:634
#define WS_BORDER
Definition: pedump.c:625
#define WS_VISIBLE
Definition: pedump.c:620
#define WS_EX_TOPMOST
Definition: pedump.c:647
long LONG
Definition: pedump.c:60
#define WS_DLGFRAME
Definition: pedump.c:626
#define WS_CLIPSIBLINGS
Definition: pedump.c:618
#define WS_CLIPCHILDREN
Definition: pedump.c:619
#define WS_THICKFRAME
Definition: pedump.c:630
#define INT
Definition: polytest.cpp:20
_Out_opt_ int _Out_opt_ int * cy
Definition: commctrl.h:586
#define TBIF_SIZE
Definition: commctrl.h:1225
#define BTNS_SHOWTEXT
Definition: commctrl.h:1006
#define CDDS_ITEMPREPAINT
Definition: commctrl.h:285
#define TBSTATE_ELLIPSES
Definition: commctrl.h:978
#define TBIF_IMAGE
Definition: commctrl.h:1219
#define TBSTYLE_TOOLTIPS
Definition: commctrl.h:989
#define TBBUTTONINFO
Definition: commctrl.h:1254
#define CDRF_NOTIFYITEMDRAW
Definition: commctrl.h:275
#define TBSTYLE_LIST
Definition: commctrl.h:993
#define CDRF_DODEFAULT
Definition: commctrl.h:268
_Out_opt_ int * cx
Definition: commctrl.h:585
#define ILC_COLOR32
Definition: commctrl.h:358
#define NM_CUSTOMDRAW
Definition: commctrl.h:137
#define TBCDRF_NOBACKGROUND
Definition: commctrl.h:1040
#define TBSTYLE_TRANSPARENT
Definition: commctrl.h:996
#define CCS_NODIVIDER
Definition: commctrl.h:2253
#define CDIS_MARKED
Definition: commctrl.h:298
#define CCS_TOP
Definition: commctrl.h:2247
#define TBMF_BUTTONSPACING
Definition: commctrl.h:1289
#define TBIF_BYINDEX
Definition: commctrl.h:1226
#define TBSTATE_ENABLED
Definition: commctrl.h:974
#define CDDS_PREPAINT
Definition: commctrl.h:280
#define TBIF_TEXT
Definition: commctrl.h:1220
#define ILC_MASK
Definition: commctrl.h:351
#define CCS_NORESIZE
Definition: commctrl.h:2250
#define TBSTATE_WRAP
Definition: commctrl.h:977
#define BTNS_CHECK
Definition: commctrl.h:1000
#define TBSTYLE_WRAPABLE
Definition: commctrl.h:990
#define TBMF_BARPAD
Definition: commctrl.h:1288
#define BTNS_NOPREFIX
Definition: commctrl.h:1005
#define TBSTATE_MARKED
Definition: commctrl.h:979
#define TBIF_COMMAND
Definition: commctrl.h:1224
#define TBSTATE_CHECKED
Definition: commctrl.h:972
struct _NMTBCUSTOMDRAW * LPNMTBCUSTOMDRAW
#define TBIF_STATE
Definition: commctrl.h:1221
#define REFIID
Definition: guiddef.h:118
_In_ DWORD dwProcessId
Definition: shlwapi.h:193
@ ASSOCSTR_EXECUTABLE
Definition: shlwapi.h:887
@ ASSOCF_NOTRUNCATE
Definition: shlwapi.h:865
_In_ UINT cchBuf
Definition: shlwapi.h:378
#define AssocQueryString
Definition: shlwapi.h:1014
#define REGSTR_PATH_EXPLORER
Definition: regstr.h:33
#define WM_CONTEXTMENU
Definition: richedit.h:64
#define WM_NOTIFY
Definition: richedit.h:61
#define DefWindowProc
Definition: ros2win.h:31
BOOL WINAPI RegisterShellHook(HWND hWnd, DWORD dwType)
Definition: shellord.c:510
BOOL WINAPI SHFindFiles(PCIDLIST_ABSOLUTE pidlFolder, PCIDLIST_ABSOLUTE pidlSaveFile)
Definition: shellord.c:2468
EXTERN_C VOID WINAPI ShellExec_RunDLLW(_In_opt_ HWND hwnd, _In_opt_ HINSTANCE hInstance, _In_ PCWSTR pszCmdLine, _In_ INT nCmdShow)
Definition: shlexec.cpp:3430
HRESULT hr
Definition: shlfolder.c:183
#define _countof(array)
Definition: sndvol32.h:70
#define TRACE(s)
Definition: solgame.cpp:4
& rect
Definition: startmenu.cpp:1413
PULONG MinorVersion OPTIONAL
Definition: CrossNt.h:68
DWORD dwMask
Definition: commctrl.h:1243
int cyButtonSpacing
Definition: commctrl.h:1299
int cxButtonSpacing
Definition: commctrl.h:1298
int cxBarPad
Definition: commctrl.h:1296
DWORD dwMask
Definition: commctrl.h:1293
int cyBarPad
Definition: commctrl.h:1297
UINT cbSize
Definition: commctrl.h:1292
BOOL bGroupButtons
Definition: precomp.h:221
BOOL bSmallIcons
Definition: precomp.h:225
NMCUSTOMDRAW nmcd
Definition: commctrl.h:1017
LONG cx
Definition: kdterminal.h:27
LONG cy
Definition: kdterminal.h:28
struct _TASK_GROUP * Next
Definition: taskswnd.cpp:148
DWORD IsCollapsed
Definition: taskswnd.cpp:159
DWORD dwTaskCount
Definition: taskswnd.cpp:150
DWORD dwFlags
Definition: taskswnd.cpp:155
DWORD dwProcessId
Definition: taskswnd.cpp:151
DWORD dwFlags
Definition: taskswnd.cpp:173
INT IconIndex
Definition: taskswnd.cpp:169
PTASK_GROUP Group
Definition: taskswnd.cpp:167
DWORD IsFlashing
Definition: taskswnd.cpp:178
DWORD RenderFlashed
Definition: taskswnd.cpp:182
BYTE fsState
Definition: commctrl.h:951
INT_PTR iString
Definition: commctrl.h:959
int idCommand
Definition: commctrl.h:950
DWORD_PTR dwData
Definition: commctrl.h:958
int iBitmap
Definition: commctrl.h:949
BYTE fsStyle
Definition: commctrl.h:952
ULONG_PTR dwData
Definition: winuser.h:3103
RECT rcMonitor
Definition: winuser.h:3887
HWND hwndFrom
Definition: winuser.h:3259
Definition: windef.h:99
LONG right
Definition: windef.h:102
LONG bottom
Definition: windef.h:103
LONG top
Definition: windef.h:101
LONG left
Definition: windef.h:100
DWORD WINAPI WaitForSingleObject(IN HANDLE hHandle, IN DWORD dwMilliseconds)
Definition: synch.c:82
struct _TASK_ITEM * PTASK_ITEM
#define VALIDATE_RUDE_MAX_COUNT
Definition: taskswnd.cpp:39
static BOOL SHELL_IsRudeWindowActive(_In_ HWND hWnd)
Definition: taskswnd.cpp:78
static BOOL SHELL_GetMonitorRect(_In_opt_ HMONITOR hMonitor, _Out_opt_ PRECT prcDest, _In_ BOOL bWorkAreaOnly)
Definition: taskswnd.cpp:42
HRESULT CTaskSwitchWnd_CreateInstance(IN HWND hWndParent, IN OUT ITrayWindow *Tray, REFIID riid, void **ppv)
Definition: taskswnd.cpp:2296
#define TASK_ITEM_ARRAY_ALLOC
Definition: taskswnd.cpp:32
struct _TASK_GROUP TASK_GROUP
#define GET_ICON(type)
const WCHAR szTaskSwitchWndClass[]
Definition: taskswnd.cpp:117
#define TIMER_ID_VALIDATE_RUDE_APP
Definition: taskswnd.cpp:37
#define MAX_TASKS_COUNT
Definition: taskswnd.cpp:31
const WCHAR szRunningApps[]
Definition: taskswnd.cpp:118
#define VALIDATE_RUDE_INTERVAL
Definition: taskswnd.cpp:38
static BOOL SHELL_IsParentOwnerOrSelf(_In_ HWND hwndTarget, _In_ HWND hWnd)
Definition: taskswnd.cpp:67
static BOOL SHELL_IsRudeWindow(_In_opt_ HMONITOR hMonitor, _In_ HWND hWnd, _In_ BOOL bDontCheckActive)
Definition: taskswnd.cpp:87
struct _TASK_GROUP * PTASK_GROUP
struct _TASK_ITEM TASK_ITEM
#define ICON_BIG
Definition: tnclass.cpp:51
#define ICON_SMALL
Definition: tnclass.cpp:48
#define DWORD_PTR
Definition: treelist.c:76
TW_UINT32 TW_UINT16 TW_UINT16 TW_MEMREF pData
Definition: twain.h:1830
int32_t INT_PTR
Definition: typedefs.h:64
uint32_t DWORD_PTR
Definition: typedefs.h:65
ULONG_PTR SIZE_T
Definition: typedefs.h:80
int32_t INT
Definition: typedefs.h:58
uint32_t ULONG_PTR
Definition: typedefs.h:65
#define IN
Definition: typedefs.h:39
uint16_t * PWCHAR
Definition: typedefs.h:56
#define HIWORD(l)
Definition: typedefs.h:247
#define OUT
Definition: typedefs.h:40
struct _BALLOON_HARD_ERROR_DATA * PBALLOON_HARD_ERROR_DATA
#define WM_KLUDGEMINRECT
Definition: undocuser.h:42
#define WM_POPUPSYSTEMMENU
Definition: undocuser.h:62
HRESULT WINAPI SetWindowTheme(_In_ HWND hwnd, _In_ LPCWSTR pszSubAppName, _In_ LPCWSTR pszSubIdList)
Definition: uxthemesupp.c:69
@ TDP_FLASHBUTTON
Definition: vssym32.h:578
_In_ WDFCOLLECTION _In_ ULONG Index
VOID WINAPI SwitchToThisWindow(HWND hwnd, BOOL fAltTab)
Definition: window.c:82
BOOL WINAPI IsHungAppWindow(HWND hwnd)
Definition: window.c:1845
DWORD WINAPI GetWindowThreadProcessId(HWND hWnd, PDWORD lpdwProcessId)
_In_ LONG _In_ HWND hwnd
Definition: winddi.h:4023
#define SubclassWindow(hwnd, lpfn)
Definition: windowsx.h:542
#define GET_Y_LPARAM(lp)
Definition: windowsx.h:300
#define GET_X_LPARAM(lp)
Definition: windowsx.h:299
HGDIOBJ WINAPI SelectObject(_In_ HDC, _In_ HGDIOBJ)
Definition: dc.c:1546
BOOL WINAPI Rectangle(_In_ HDC, _In_ int, _In_ int, _In_ int, _In_ int)
#define WM_ERASEBKGND
Definition: winuser.h:1653
DWORD WINAPI GetSysColor(_In_ int)
#define HSHELL_RUDEAPPACTIVATED
Definition: winuser.h:1292
#define SM_CXMINIMIZED
Definition: winuser.h:1031
#define SWP_NOACTIVATE
Definition: winuser.h:1253
#define GetWindowLongPtrW
Definition: winuser.h:4931
#define SM_CYEDGE
Definition: winuser.h:1020
#define WM_QUIT
Definition: winuser.h:1651
#define GCLP_HICONSM
Definition: winuser.h:683
#define MAKELPARAM(l, h)
Definition: winuser.h:4110
#define HSHELL_ACTIVATESHELLWINDOW
Definition: winuser.h:1268
#define SM_CYSCREEN
Definition: winuser.h:971
HWND WINAPI GetForegroundWindow(void)
Definition: ntwrapper.h:392
#define SM_CXEDGE
Definition: winuser.h:1019
BOOL WINAPI PostMessageW(_In_opt_ HWND, _In_ UINT, _In_ WPARAM, _In_ LPARAM)
#define HSHELL_WINDOWDESTROYED
Definition: winuser.h:1267
#define IMAGE_ICON
Definition: winuser.h:212
#define GCLP_HICON
Definition: winuser.h:682
BOOL WINAPI GetWindowRect(_In_ HWND, _Out_ LPRECT)
#define WM_CREATE
Definition: winuser.h:1636
int WINAPIV wsprintfW(_Out_ LPWSTR, _In_ _Printf_format_string_ LPCWSTR,...)
#define SW_MINIMIZE
Definition: winuser.h:787
#define HSHELL_WINDOWCREATED
Definition: winuser.h:1266
BOOL WINAPI SetWindowPos(_In_ HWND, _In_opt_ HWND, _In_ int, _In_ int, _In_ int, _In_ int, _In_ UINT)
#define WM_SIZE
Definition: winuser.h:1639
#define COLOR_HIGHLIGHT
Definition: winuser.h:937
HBRUSH WINAPI GetSysColorBrush(_In_ int)
struct tagCOPYDATASTRUCT * PCOPYDATASTRUCT
#define SWP_NOMOVE
Definition: winuser.h:1255
#define WM_COMMAND
Definition: winuser.h:1768
#define HTVSCROLL
Definition: winuser.h:2518
BOOL WINAPI SetForegroundWindow(_In_ HWND)
HANDLE WINAPI LoadImageW(_In_opt_ HINSTANCE hInst, _In_ LPCWSTR name, _In_ UINT type, _In_ int cx, _In_ int cy, _In_ UINT fuLoad)
Definition: cursoricon.c:2555
#define HTHSCROLL
Definition: winuser.h:2517
BOOL WINAPI GetCursorPos(_Out_ LPPOINT)
Definition: cursoricon.c:3047
#define WM_NCHITTEST
Definition: winuser.h:1714
#define SM_CYSMICON
Definition: winuser.h:1024
BOOL WINAPI IsRectEmpty(_In_ LPCRECT)
BOOL WINAPI EnumDisplayMonitors(_In_opt_ HDC, _In_opt_ LPCRECT, _In_ MONITORENUMPROC, _In_ LPARAM)
#define SWP_NOSIZE
Definition: winuser.h:1256
#define GetClassLongPtr
Definition: winuser.h:5893
#define MA_NOACTIVATE
Definition: winuser.h:2539
#define CS_DBLCLKS
Definition: winuser.h:659
#define PostThreadMessage
Definition: winuser.h:5944
int WINAPI MapWindowPoints(_In_opt_ HWND hWndFrom, _In_opt_ HWND hWndTo, _Inout_updates_(cPoints) LPPOINT lpPoints, _In_ UINT cPoints)
BOOL WINAPI SendMessageCallbackW(_In_ HWND, _In_ UINT, _In_ WPARAM, _In_ LPARAM, _In_ SENDASYNCPROC, _In_ ULONG_PTR)
#define SM_CXSIZE
Definition: winuser.h:1002
UINT_PTR WINAPI SetTimer(_In_opt_ HWND, _In_ UINT_PTR, _In_ UINT, _In_opt_ TIMERPROC)
HWND WINAPI GetDesktopWindow(void)
Definition: window.c:628
BOOL WINAPI ShowWindowAsync(_In_ HWND, _In_ int)
#define WM_SETTINGCHANGE
Definition: winuser.h:1657
#define SM_CXSMICON
Definition: winuser.h:1023
BOOL WINAPI GetClientRect(_In_ HWND, _Out_ LPRECT)
#define SM_CYICON
Definition: winuser.h:984
BOOL WINAPI EnumWindows(_In_ WNDENUMPROC lpEnumFunc, _In_ LPARAM lParam)
#define WM_SETFONT
Definition: winuser.h:1678
#define WM_TIMER
Definition: winuser.h:1770
BOOL WINAPI IntersectRect(_Out_ LPRECT, _In_ LPCRECT, _In_ LPCRECT)
#define WM_COPYDATA
Definition: winuser.h:1692
#define WM_NULL
Definition: winuser.h:1635
#define SendMessage
Definition: winuser.h:5954
UINT WINAPI RegisterWindowMessageW(_In_ LPCWSTR)
#define COLOR_HIGHLIGHTTEXT
Definition: winuser.h:938
#define HSHELL_FLASH
Definition: winuser.h:1291
#define WM_MOUSEACTIVATE
Definition: winuser.h:1665
#define LR_SHARED
Definition: winuser.h:1111
BOOL WINAPI SystemParametersInfoW(_In_ UINT uiAction, _In_ UINT uiParam, _Inout_opt_ PVOID pvParam, _In_ UINT fWinIni)
#define PostMessage
Definition: winuser.h:5943
HWND WINAPI GetParent(_In_ HWND)
#define HTTRANSPARENT
Definition: winuser.h:2509
#define SWP_NOOWNERZORDER
Definition: winuser.h:1260
BOOL WINAPI OffsetRect(_Inout_ LPRECT, _In_ int, _In_ int)
#define SW_SHOW
Definition: winuser.h:786
#define WM_DESTROY
Definition: winuser.h:1637
#define LR_DEFAULTSIZE
Definition: winuser.h:1105
#define SM_CXSCREEN
Definition: winuser.h:970
BOOL WINAPI GetMonitorInfoW(_In_ HMONITOR, _Inout_ LPMONITORINFO)
#define MAKEINTRESOURCEW(i)
Definition: winuser.h:582
#define SWP_NOZORDER
Definition: winuser.h:1258
BOOL WINAPI KillTimer(_In_opt_ HWND, _In_ UINT_PTR)
BOOL WINAPI UnionRect(_Out_ LPRECT, _In_ LPCRECT, _In_ LPCRECT)
INT WINAPI InternalGetWindowText(_In_ HWND hWnd, _Out_writes_to_(cchMaxCount, return+1) LPWSTR pString, _In_ int cchMaxCount)
#define GWL_STYLE
Definition: winuser.h:863
#define SM_CXICON
Definition: winuser.h:983
#define WM_WINDOWPOSCHANGED
Definition: winuser.h:1690
BOOL WINAPI IsWindowVisible(_In_ HWND)
BOOL WINAPI EqualRect(_In_ LPCRECT, _In_ LPCRECT)
int WINAPI GetSystemMetrics(_In_ int)
#define HWND_BOTTOM
Definition: winuser.h:1216
LRESULT WINAPI SendMessageW(_In_ HWND, _In_ UINT, _In_ WPARAM, _In_ LPARAM)
#define GWL_EXSTYLE
Definition: winuser.h:862
#define COLOR_3DFACE
Definition: winuser.h:940
#define WM_SETREDRAW
Definition: winuser.h:1644
BOOL WINAPI ScreenToClient(_In_ HWND, _Inout_ LPPOINT)
static void Initialize()
Definition: xlate.c:212
#define IID_PPV_ARG(Itype, ppType)
const WCHAR * LPCWSTR
Definition: xmlstorage.h:185
__wchar_t WCHAR
Definition: xmlstorage.h:180
WCHAR * LPWSTR
Definition: xmlstorage.h:184