aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llwindow
diff options
context:
space:
mode:
authorJacek Antonelli2008-09-28 17:21:23 -0500
committerJacek Antonelli2008-09-28 17:21:46 -0500
commit31e7c77a411d94bc87f0232588b339149bb29a49 (patch)
tree49e487700e91713e620e4d33f20b7f7afb5a2fa9 /linden/indra/llwindow
parentSecond Life viewer sources 1.21.2-RC (diff)
downloadmeta-impy-31e7c77a411d94bc87f0232588b339149bb29a49.zip
meta-impy-31e7c77a411d94bc87f0232588b339149bb29a49.tar.gz
meta-impy-31e7c77a411d94bc87f0232588b339149bb29a49.tar.bz2
meta-impy-31e7c77a411d94bc87f0232588b339149bb29a49.tar.xz
Second Life viewer sources 1.21.3-RC
Diffstat (limited to 'linden/indra/llwindow')
-rw-r--r--linden/indra/llwindow/llwindow.cpp11
-rw-r--r--linden/indra/llwindow/llwindow.h4
-rw-r--r--linden/indra/llwindow/llwindowwin32.cpp48
3 files changed, 62 insertions, 1 deletions
diff --git a/linden/indra/llwindow/llwindow.cpp b/linden/indra/llwindow/llwindow.cpp
index f4ee8cc..e8b0a1b 100644
--- a/linden/indra/llwindow/llwindow.cpp
+++ b/linden/indra/llwindow/llwindow.cpp
@@ -208,6 +208,17 @@ void LLWindowCallbacks::handlePingWatchdog(LLWindow *window, const char * msg)
208 208
209} 209}
210 210
211void LLWindowCallbacks::handlePauseWatchdog(LLWindow *window)
212{
213
214}
215
216void LLWindowCallbacks::handleResumeWatchdog(LLWindow *window)
217{
218
219}
220
221
211S32 OSMessageBox(const std::string& text, const std::string& caption, U32 type) 222S32 OSMessageBox(const std::string& text, const std::string& caption, U32 type)
212{ 223{
213 // Properly hide the splash screen when displaying the message box 224 // Properly hide the splash screen when displaying the message box
diff --git a/linden/indra/llwindow/llwindow.h b/linden/indra/llwindow/llwindow.h
index cee83b9..7e948b9 100644
--- a/linden/indra/llwindow/llwindow.h
+++ b/linden/indra/llwindow/llwindow.h
@@ -119,7 +119,11 @@ public:
119 virtual void handleDataCopy(LLWindow *window, S32 data_type, void *data); 119 virtual void handleDataCopy(LLWindow *window, S32 data_type, void *data);
120 virtual BOOL handleTimerEvent(LLWindow *window); 120 virtual BOOL handleTimerEvent(LLWindow *window);
121 virtual BOOL handleDeviceChange(LLWindow *window); 121 virtual BOOL handleDeviceChange(LLWindow *window);
122
122 virtual void handlePingWatchdog(LLWindow *window, const char * msg); 123 virtual void handlePingWatchdog(LLWindow *window, const char * msg);
124 virtual void handlePauseWatchdog(LLWindow *window);
125 virtual void handleResumeWatchdog(LLWindow *window);
126
123}; 127};
124 128
125// Refer to llwindow_test in test/common/llwindow for usage example 129// Refer to llwindow_test in test/common/llwindow for usage example
diff --git a/linden/indra/llwindow/llwindowwin32.cpp b/linden/indra/llwindow/llwindowwin32.cpp
index 3729a71..ef3cf68 100644
--- a/linden/indra/llwindow/llwindowwin32.cpp
+++ b/linden/indra/llwindow/llwindowwin32.cpp
@@ -1577,8 +1577,11 @@ void LLWindowWin32::gatherInput()
1577 { 1577 {
1578 mCallbacks->handlePingWatchdog(this, "Main:TranslateGatherInput"); 1578 mCallbacks->handlePingWatchdog(this, "Main:TranslateGatherInput");
1579 TranslateMessage(&msg); 1579 TranslateMessage(&msg);
1580 mCallbacks->handlePingWatchdog(this, "Main:DispatchGatherInput"); 1580
1581 // turn watchdog off in here to not fail if windows is doing something wacky
1582 mCallbacks->handlePauseWatchdog(this);
1581 DispatchMessage(&msg); 1583 DispatchMessage(&msg);
1584 mCallbacks->handleResumeWatchdog(this);
1582 msg_count++; 1585 msg_count++;
1583 1586
1584 if ( mInputProcessingPaused ) 1587 if ( mInputProcessingPaused )
@@ -1623,8 +1626,11 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1623{ 1626{
1624 LLWindowWin32 *window_imp = (LLWindowWin32 *)GetWindowLong(h_wnd, GWL_USERDATA); 1627 LLWindowWin32 *window_imp = (LLWindowWin32 *)GetWindowLong(h_wnd, GWL_USERDATA);
1625 1628
1629
1626 if (NULL != window_imp) 1630 if (NULL != window_imp)
1627 { 1631 {
1632 window_imp->mCallbacks->handleResumeWatchdog(window_imp);
1633 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:StartWndProc");
1628 // Has user provided their own window callback? 1634 // Has user provided their own window callback?
1629 if (NULL != window_imp->mWndProc) 1635 if (NULL != window_imp->mWndProc)
1630 { 1636 {
@@ -1635,6 +1641,8 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1635 } 1641 }
1636 } 1642 }
1637 1643
1644 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:PreSwitchWndProc");
1645
1638 // Juggle to make sure we can get negative positions for when 1646 // Juggle to make sure we can get negative positions for when
1639 // mouse is outside window. 1647 // mouse is outside window.
1640 LLCoordWindow window_coord((S32)(S16)LOWORD(l_param), (S32)(S16)HIWORD(l_param)); 1648 LLCoordWindow window_coord((S32)(S16)LOWORD(l_param), (S32)(S16)HIWORD(l_param));
@@ -1654,10 +1662,12 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1654 S32 update_height; 1662 S32 update_height;
1655 1663
1656 case WM_TIMER: 1664 case WM_TIMER:
1665 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_TIMER");
1657 window_imp->mCallbacks->handleTimerEvent(window_imp); 1666 window_imp->mCallbacks->handleTimerEvent(window_imp);
1658 break; 1667 break;
1659 1668
1660 case WM_DEVICECHANGE: 1669 case WM_DEVICECHANGE:
1670 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_DEVICECHANGE");
1661 if (gDebugWindowProc) 1671 if (gDebugWindowProc)
1662 { 1672 {
1663 llinfos << " WM_DEVICECHANGE: wParam=" << w_param 1673 llinfos << " WM_DEVICECHANGE: wParam=" << w_param
@@ -1673,6 +1683,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1673 break; 1683 break;
1674 1684
1675 case WM_PAINT: 1685 case WM_PAINT:
1686 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_PAINT");
1676 GetUpdateRect(window_imp->mWindowHandle, &update_rect, FALSE); 1687 GetUpdateRect(window_imp->mWindowHandle, &update_rect, FALSE);
1677 update_width = update_rect.right - update_rect.left + 1; 1688 update_width = update_rect.right - update_rect.left + 1;
1678 update_height = update_rect.bottom - update_rect.top + 1; 1689 update_height = update_rect.bottom - update_rect.top + 1;
@@ -1680,6 +1691,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1680 update_width, update_height); 1691 update_width, update_height);
1681 break; 1692 break;
1682 case WM_PARENTNOTIFY: 1693 case WM_PARENTNOTIFY:
1694 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_PARENTNOTIFY");
1683 u_msg = u_msg; 1695 u_msg = u_msg;
1684 break; 1696 break;
1685 1697
@@ -1689,6 +1701,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1689 1701
1690 // Only take control of cursor over client region of window 1702 // Only take control of cursor over client region of window
1691 // This allows Windows(tm) to handle resize cursors, etc. 1703 // This allows Windows(tm) to handle resize cursors, etc.
1704 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_SETCURSOR");
1692 if (LOWORD(l_param) == HTCLIENT) 1705 if (LOWORD(l_param) == HTCLIENT)
1693 { 1706 {
1694 SetCursor(window_imp->mCursor[ window_imp->mCurrentCursor] ); 1707 SetCursor(window_imp->mCursor[ window_imp->mCurrentCursor] );
@@ -1697,14 +1710,17 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1697 break; 1710 break;
1698 1711
1699 case WM_ENTERMENULOOP: 1712 case WM_ENTERMENULOOP:
1713 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_ENTERMENULOOP");
1700 window_imp->mCallbacks->handleWindowBlock(window_imp); 1714 window_imp->mCallbacks->handleWindowBlock(window_imp);
1701 break; 1715 break;
1702 1716
1703 case WM_EXITMENULOOP: 1717 case WM_EXITMENULOOP:
1718 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_EXITMENULOOP");
1704 window_imp->mCallbacks->handleWindowUnblock(window_imp); 1719 window_imp->mCallbacks->handleWindowUnblock(window_imp);
1705 break; 1720 break;
1706 1721
1707 case WM_ACTIVATEAPP: 1722 case WM_ACTIVATEAPP:
1723 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_ACTIVATEAPP");
1708 { 1724 {
1709 // This message should be sent whenever the app gains or loses focus. 1725 // This message should be sent whenever the app gains or loses focus.
1710 BOOL activating = (BOOL) w_param; 1726 BOOL activating = (BOOL) w_param;
@@ -1741,6 +1757,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1741 } 1757 }
1742 1758
1743 case WM_ACTIVATE: 1759 case WM_ACTIVATE:
1760 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_ACTIVATE");
1744 { 1761 {
1745 // Can be one of WA_ACTIVE, WA_CLICKACTIVE, or WA_INACTIVE 1762 // Can be one of WA_ACTIVE, WA_CLICKACTIVE, or WA_INACTIVE
1746 BOOL activating = (LOWORD(w_param) != WA_INACTIVE); 1763 BOOL activating = (LOWORD(w_param) != WA_INACTIVE);
@@ -1772,6 +1789,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1772 break; 1789 break;
1773 1790
1774 case WM_SYSCOMMAND: 1791 case WM_SYSCOMMAND:
1792 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_SYSCOMMAND");
1775 switch(w_param) 1793 switch(w_param)
1776 { 1794 {
1777 case SC_KEYMENU: 1795 case SC_KEYMENU:
@@ -1786,6 +1804,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1786 break; 1804 break;
1787 1805
1788 case WM_CLOSE: 1806 case WM_CLOSE:
1807 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_CLOSE");
1789 // Will the app allow the window to close? 1808 // Will the app allow the window to close?
1790 if (window_imp->mCallbacks->handleCloseRequest(window_imp)) 1809 if (window_imp->mCallbacks->handleCloseRequest(window_imp))
1791 { 1810 {
@@ -1796,6 +1815,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1796 return 0; 1815 return 0;
1797 1816
1798 case WM_DESTROY: 1817 case WM_DESTROY:
1818 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_DESTROY");
1799 if (window_imp->shouldPostQuit()) 1819 if (window_imp->shouldPostQuit())
1800 { 1820 {
1801 PostQuitMessage(0); // Posts WM_QUIT with an exit code of 0 1821 PostQuitMessage(0); // Posts WM_QUIT with an exit code of 0
@@ -1803,6 +1823,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1803 return 0; 1823 return 0;
1804 1824
1805 case WM_COMMAND: 1825 case WM_COMMAND:
1826 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_COMMAND");
1806 if (!HIWORD(w_param)) // this message is from a menu 1827 if (!HIWORD(w_param)) // this message is from a menu
1807 { 1828 {
1808 window_imp->mCallbacks->handleMenuSelect(window_imp, LOWORD(w_param)); 1829 window_imp->mCallbacks->handleMenuSelect(window_imp, LOWORD(w_param));
@@ -1810,9 +1831,11 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1810 break; 1831 break;
1811 1832
1812 case WM_SYSKEYDOWN: 1833 case WM_SYSKEYDOWN:
1834 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_SYSKEYDOWN");
1813 // allow system keys, such as ALT-F4 to be processed by Windows 1835 // allow system keys, such as ALT-F4 to be processed by Windows
1814 eat_keystroke = FALSE; 1836 eat_keystroke = FALSE;
1815 case WM_KEYDOWN: 1837 case WM_KEYDOWN:
1838 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_KEYDOWN");
1816 { 1839 {
1817 if (gDebugWindowProc) 1840 if (gDebugWindowProc)
1818 { 1841 {
@@ -1831,6 +1854,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1831 eat_keystroke = FALSE; 1854 eat_keystroke = FALSE;
1832 case WM_KEYUP: 1855 case WM_KEYUP:
1833 { 1856 {
1857 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_KEYUP");
1834 LLFastTimer t2(LLFastTimer::FTM_KEYHANDLER); 1858 LLFastTimer t2(LLFastTimer::FTM_KEYHANDLER);
1835 1859
1836 if (gDebugWindowProc) 1860 if (gDebugWindowProc)
@@ -1848,6 +1872,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1848 break; 1872 break;
1849 } 1873 }
1850 case WM_IME_SETCONTEXT: 1874 case WM_IME_SETCONTEXT:
1875 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_IME_SETCONTEXT");
1851 if (gDebugWindowProc) 1876 if (gDebugWindowProc)
1852 { 1877 {
1853 llinfos << "WM_IME_SETCONTEXT" << llendl; 1878 llinfos << "WM_IME_SETCONTEXT" << llendl;
@@ -1860,6 +1885,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1860 break; 1885 break;
1861 1886
1862 case WM_IME_STARTCOMPOSITION: 1887 case WM_IME_STARTCOMPOSITION:
1888 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_IME_STARTCOMPOSITION");
1863 if (gDebugWindowProc) 1889 if (gDebugWindowProc)
1864 { 1890 {
1865 llinfos << "WM_IME_STARTCOMPOSITION" << llendl; 1891 llinfos << "WM_IME_STARTCOMPOSITION" << llendl;
@@ -1872,6 +1898,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1872 break; 1898 break;
1873 1899
1874 case WM_IME_ENDCOMPOSITION: 1900 case WM_IME_ENDCOMPOSITION:
1901 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_IME_ENDCOMPOSITION");
1875 if (gDebugWindowProc) 1902 if (gDebugWindowProc)
1876 { 1903 {
1877 llinfos << "WM_IME_ENDCOMPOSITION" << llendl; 1904 llinfos << "WM_IME_ENDCOMPOSITION" << llendl;
@@ -1883,6 +1910,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1883 break; 1910 break;
1884 1911
1885 case WM_IME_COMPOSITION: 1912 case WM_IME_COMPOSITION:
1913 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_IME_COMPOSITION");
1886 if (gDebugWindowProc) 1914 if (gDebugWindowProc)
1887 { 1915 {
1888 llinfos << "WM_IME_COMPOSITION" << llendl; 1916 llinfos << "WM_IME_COMPOSITION" << llendl;
@@ -1895,6 +1923,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1895 break; 1923 break;
1896 1924
1897 case WM_IME_REQUEST: 1925 case WM_IME_REQUEST:
1926 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_IME_REQUEST");
1898 if (gDebugWindowProc) 1927 if (gDebugWindowProc)
1899 { 1928 {
1900 llinfos << "WM_IME_REQUEST" << llendl; 1929 llinfos << "WM_IME_REQUEST" << llendl;
@@ -1920,6 +1949,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1920 // it is worth trying. The good old WM_CHAR works just fine even for supplementary 1949 // it is worth trying. The good old WM_CHAR works just fine even for supplementary
1921 // characters. We just need to take care of surrogate pairs sent as two WM_CHAR's 1950 // characters. We just need to take care of surrogate pairs sent as two WM_CHAR's
1922 // by ourselves. It is not that tough. -- Alissa Sabre @ SL 1951 // by ourselves. It is not that tough. -- Alissa Sabre @ SL
1952 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_CHAR");
1923 if (gDebugWindowProc) 1953 if (gDebugWindowProc)
1924 { 1954 {
1925 LL_INFOS("Window") << "Debug WindowProc WM_CHAR " 1955 LL_INFOS("Window") << "Debug WindowProc WM_CHAR "
@@ -1933,6 +1963,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1933 1963
1934 case WM_LBUTTONDOWN: 1964 case WM_LBUTTONDOWN:
1935 { 1965 {
1966 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_LBUTTONDOWN");
1936 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER); 1967 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER);
1937 if (LLWinImm::isAvailable() && window_imp->mPreeditor) 1968 if (LLWinImm::isAvailable() && window_imp->mPreeditor)
1938 { 1969 {
@@ -1968,6 +1999,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1968 //RN: ignore right button double clicks for now 1999 //RN: ignore right button double clicks for now
1969 //case WM_RBUTTONDBLCLK: 2000 //case WM_RBUTTONDBLCLK:
1970 { 2001 {
2002 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_LBUTTONDBLCLK");
1971 // Because we move the cursor position in the app, we need to query 2003 // Because we move the cursor position in the app, we need to query
1972 // to find out where the cursor at the time the event is handled. 2004 // to find out where the cursor at the time the event is handled.
1973 // If we don't do this, many clicks could get buffered up, and if the 2005 // If we don't do this, many clicks could get buffered up, and if the
@@ -1995,6 +2027,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
1995 2027
1996 case WM_LBUTTONUP: 2028 case WM_LBUTTONUP:
1997 { 2029 {
2030 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_LBUTTONUP");
1998 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER); 2031 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER);
1999 //if (gDebugClicks) 2032 //if (gDebugClicks)
2000 //{ 2033 //{
@@ -2028,6 +2061,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2028 case WM_RBUTTONDBLCLK: 2061 case WM_RBUTTONDBLCLK:
2029 case WM_RBUTTONDOWN: 2062 case WM_RBUTTONDOWN:
2030 { 2063 {
2064 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_RBUTTONDOWN");
2031 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER); 2065 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER);
2032 if (LLWinImm::isAvailable() && window_imp->mPreeditor) 2066 if (LLWinImm::isAvailable() && window_imp->mPreeditor)
2033 { 2067 {
@@ -2061,6 +2095,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2061 2095
2062 case WM_RBUTTONUP: 2096 case WM_RBUTTONUP:
2063 { 2097 {
2098 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_RBUTTONUP");
2064 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER); 2099 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER);
2065 // Because we move the cursor position in the app, we need to query 2100 // Because we move the cursor position in the app, we need to query
2066 // to find out where the cursor at the time the event is handled. 2101 // to find out where the cursor at the time the event is handled.
@@ -2090,6 +2125,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2090 case WM_MBUTTONDOWN: 2125 case WM_MBUTTONDOWN:
2091// case WM_MBUTTONDBLCLK: 2126// case WM_MBUTTONDBLCLK:
2092 { 2127 {
2128 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_MBUTTONDOWN");
2093 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER); 2129 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER);
2094 if (LLWinImm::isAvailable() && window_imp->mPreeditor) 2130 if (LLWinImm::isAvailable() && window_imp->mPreeditor)
2095 { 2131 {
@@ -2123,6 +2159,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2123 2159
2124 case WM_MBUTTONUP: 2160 case WM_MBUTTONUP:
2125 { 2161 {
2162 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_MBUTTONUP");
2126 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER); 2163 LLFastTimer t2(LLFastTimer::FTM_MOUSEHANDLER);
2127 // Because we move the cursor position in tllviewerhe app, we need to query 2164 // Because we move the cursor position in tllviewerhe app, we need to query
2128 // to find out where the cursor at the time the event is handled. 2165 // to find out where the cursor at the time the event is handled.
@@ -2151,6 +2188,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2151 2188
2152 case WM_MOUSEWHEEL: 2189 case WM_MOUSEWHEEL:
2153 { 2190 {
2191 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_MOUSEWHEEL");
2154 static short z_delta = 0; 2192 static short z_delta = 0;
2155 2193
2156 z_delta += HIWORD(w_param); 2194 z_delta += HIWORD(w_param);
@@ -2187,6 +2225,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2187 // Handle mouse movement within the window 2225 // Handle mouse movement within the window
2188 case WM_MOUSEMOVE: 2226 case WM_MOUSEMOVE:
2189 { 2227 {
2228 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_MOUSEMOVE");
2190 window_imp->convertCoords(window_coord, &gl_coord); 2229 window_imp->convertCoords(window_coord, &gl_coord);
2191 MASK mask = gKeyboard->currentMask(TRUE); 2230 MASK mask = gKeyboard->currentMask(TRUE);
2192 window_imp->mCallbacks->handleMouseMove(window_imp, gl_coord, mask); 2231 window_imp->mCallbacks->handleMouseMove(window_imp, gl_coord, mask);
@@ -2195,6 +2234,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2195 2234
2196 case WM_SIZE: 2235 case WM_SIZE:
2197 { 2236 {
2237 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_SIZE");
2198 S32 width = S32( LOWORD(l_param) ); 2238 S32 width = S32( LOWORD(l_param) );
2199 S32 height = S32( HIWORD(l_param) ); 2239 S32 height = S32( HIWORD(l_param) );
2200 2240
@@ -2253,6 +2293,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2253 } 2293 }
2254 2294
2255 case WM_SETFOCUS: 2295 case WM_SETFOCUS:
2296 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_SETFOCUS");
2256 if (gDebugWindowProc) 2297 if (gDebugWindowProc)
2257 { 2298 {
2258 LL_INFOS("Window") << "WINDOWPROC SetFocus" << LL_ENDL; 2299 LL_INFOS("Window") << "WINDOWPROC SetFocus" << LL_ENDL;
@@ -2261,6 +2302,7 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2261 return 0; 2302 return 0;
2262 2303
2263 case WM_KILLFOCUS: 2304 case WM_KILLFOCUS:
2305 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_KILLFOCUS");
2264 if (gDebugWindowProc) 2306 if (gDebugWindowProc)
2265 { 2307 {
2266 LL_INFOS("Window") << "WINDOWPROC KillFocus" << LL_ENDL; 2308 LL_INFOS("Window") << "WINDOWPROC KillFocus" << LL_ENDL;
@@ -2269,13 +2311,17 @@ LRESULT CALLBACK LLWindowWin32::mainWindowProc(HWND h_wnd, UINT u_msg, WPARAM w_
2269 return 0; 2311 return 0;
2270 2312
2271 case WM_COPYDATA: 2313 case WM_COPYDATA:
2314 window_imp->mCallbacks->handlePingWatchdog(window_imp, "Main:WM_COPYDATA");
2272 // received a URL 2315 // received a URL
2273 PCOPYDATASTRUCT myCDS = (PCOPYDATASTRUCT) l_param; 2316 PCOPYDATASTRUCT myCDS = (PCOPYDATASTRUCT) l_param;
2274 window_imp->mCallbacks->handleDataCopy(window_imp, myCDS->dwData, myCDS->lpData); 2317 window_imp->mCallbacks->handleDataCopy(window_imp, myCDS->dwData, myCDS->lpData);
2275 return 0; 2318 return 0;
2276 } 2319 }
2320
2321 window_imp->mCallbacks->handlePauseWatchdog(window_imp);
2277 } 2322 }
2278 2323
2324
2279 // pass unhandled messages down to Windows 2325 // pass unhandled messages down to Windows
2280 return DefWindowProc(h_wnd, u_msg, w_param, l_param); 2326 return DefWindowProc(h_wnd, u_msg, w_param, l_param);
2281} 2327}