1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4 *
5 * The contents of this file are subject to the Mozilla Public License Version
6 * 1.1 (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 * http://www.mozilla.org/MPL/
9 *
10 * Software distributed under the License is distributed on an "AS IS" basis,
11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 * for the specific language governing rights and limitations under the
13 * License.
14 *
15 * The Original Code is mozilla.org code.
16 *
17 * The Initial Developer of the Original Code is
18 * Netscape Communications Corporation.
19 * Portions created by the Initial Developer are Copyright (C) 1998
20 * the Initial Developer. All Rights Reserved.
21 *
22 * Contributor(s):
23 *
24 * Alternatively, the contents of this file may be used under the terms of
25 * either the GNU General Public License Version 2 or later (the "GPL"), or
26 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27 * in which case the provisions of the GPL or the LGPL are applicable instead
28 * of those above. If you wish to allow use of your version of this file only
29 * under the terms of either the GPL or the LGPL, and not to allow others to
30 * use your version of this file under the terms of the MPL, indicate your
31 * decision by deleting the provisions above and replace them with the notice
32 * and other provisions required by the GPL or the LGPL. If you do not delete
33 * the provisions above, a recipient may use your version of this file under
34 * the terms of any one of the MPL, the GPL or the LGPL.
35 *
36 * ***** END LICENSE BLOCK ***** */
37
38 #include "xp.h"
39 #include "windowsx.h"
40
41 #include "resource.h"
42 #include "loggerw.h"
43 #include "profilew.h"
44 #include "actionnames.h"
45
46 extern HINSTANCE hInst;
47 static char szClassName[] = "NPSpyWindowClass";
48
49 BOOL CALLBACK MainDlgProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
50 BOOL CALLBACK PauseDlgProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
51
LoggerWin()52 LoggerWin::LoggerWin() : Logger(),
53 hWnd(NULL),
54 width(0),
55 height(0),
56 x(0),
57 y(0),
58 bSaveSettings(FALSE)
59 {
60 }
61
~LoggerWin()62 LoggerWin::~LoggerWin()
63 {
64 }
65
platformInit()66 BOOL LoggerWin::platformInit()
67 {
68 WNDCLASS wc;
69 wc.style = 0;
70 wc.lpfnWndProc = DefDlgProc;
71 wc.cbClsExtra = 0;
72 wc.cbWndExtra = DLGWINDOWEXTRA;
73 wc.hInstance = hInst;
74 wc.hIcon = LoadIcon(hInst, MAKEINTRESOURCE(IDI_ICON_APP));
75 wc.hCursor = LoadCursor(0, IDC_ARROW);
76 wc.hbrBackground = (HBRUSH)(COLOR_BTNFACE + 1);
77 wc.lpszMenuName = NULL;
78 wc.lpszClassName = szClassName;
79
80 if(!RegisterClass(&wc))
81 return FALSE;
82
83 // restore prefs
84 ProfileWin profile;
85
86 profile.getBool(NPSPY_REG_KEY_ONTOP, &bOnTop);
87 bOnTop = false; // XXXMB
88 profile.getBool(NPSPY_REG_KEY_LOGTOWINDOW, &bToWindow);
89 profile.getBool(NPSPY_REG_KEY_LOGTOCONSOLE, &bToConsole);
90 profile.getBool(NPSPY_REG_KEY_LOGTOFILE, &bToFile);
91 profile.getBool(NPSPY_REG_KEY_SPALID, &bSPALID);
92 profile.getString(NPSPY_REG_KEY_LOGFILENAME, szFile, strlen(szFile));
93
94 for(int i = 1; i < TOTAL_NUMBER_OF_API_CALLS; i++)
95 {
96 BOOL selected = TRUE;
97 if(profile.getBool(ActionName[i], &selected))
98 bMutedCalls[i] = !selected;
99 }
100
101 if(!profile.getSizeAndPosition(&width, &height, &x, &y))
102 {
103 width = 0;
104 height = 0;
105 x = 0;
106 y = 0;
107 }
108
109 hWnd = CreateDialogParam(hInst, MAKEINTRESOURCE(IDD_DIALOG_MAIN), GetDesktopWindow(), (DLGPROC)MainDlgProc, (LPARAM)this);
110 if(hWnd == NULL)
111 {
112 UnregisterClass(szClassName, hInst);
113 return FALSE;
114 }
115
116 if(bOnTop)
117 SetWindowPos(hWnd, bOnTop ? HWND_TOPMOST : HWND_NOTOPMOST, 0,0,0,0, SWP_NOMOVE | SWP_NOSIZE);
118
119 return TRUE;
120 }
121
platformShut()122 void LoggerWin::platformShut()
123 {
124 if(hWnd != NULL)
125 {
126 char szLog[] = "--- GOING AWAY... PRESS SPACE BAR TO CONTINUE ---";
127 HWND hWndOutput = GetDlgItem(hWnd, IDC_MAIN_OUTPUT);
128 ListBox_AddString(hWndOutput, "");
129 ListBox_AddString(hWndOutput, szLog);
130 int count = ListBox_GetCount(hWndOutput);
131 ListBox_SetCaretIndex(hWndOutput, count - 1);
132 UpdateWindow(hWndOutput);
133
134 DialogBox(hInst, MAKEINTRESOURCE(IDD_DIALOG_PAUSE), hWnd, (DLGPROC)PauseDlgProc);
135
136 ProfileWin profile;
137
138 RECT rc;
139 if(GetWindowRect(hWnd, &rc))
140 profile.setSizeAndPosition(rc.right - rc.left, rc.bottom - rc.top, rc.left, rc.top);
141
142 DestroyWindow(hWnd);
143 hWnd = NULL;
144 }
145
146 UnregisterClass(szClassName, hInst);
147 }
148
onDestroyWindow()149 void LoggerWin::onDestroyWindow()
150 {
151 hWnd = NULL;
152 }
153
dumpStringToMainWindow(const std::string & string)154 void LoggerWin::dumpStringToMainWindow(const std::string& string)
155 {
156 const char* output = string.c_str();
157 std::string temp_string;
158 // listboxes don't want <CR> and <LF> so cut them off if any. The order is important.
159 size_t newline = string.find('\n');
160 if(newline != std::string::npos) {
161 // make copy of string since it might be a constant
162 temp_string = string;
163
164 char* p = strrchr(const_cast<char*>(temp_string.c_str()), '\n');
165 *p = '\0';
166
167 p = strrchr(const_cast<char*>(temp_string.c_str()), '\r');
168 if(p)
169 *p = '\0';
170 output = temp_string.c_str();
171 }
172
173 HWND hWndOutput = GetDlgItem(hWnd, IDC_MAIN_OUTPUT);
174 ListBox_AddString(hWndOutput, output);
175 int count = ListBox_GetCount(hWndOutput);
176 if(count == 32767)
177 ListBox_ResetContent(hWndOutput);
178 ListBox_SetCaretIndex(hWndOutput, count - 1);
179 UpdateWindow(hWndOutput);
180 }
181
onClear()182 void LoggerWin::onClear()
183 {
184 HWND hWndOutput = GetDlgItem(hWnd, IDC_MAIN_OUTPUT);
185 ListBox_ResetContent(hWndOutput);
186 UpdateWindow(hWndOutput);
187 }
188
NewLogger()189 Logger * NewLogger()
190 {
191 LoggerWin * res = new LoggerWin();
192 return res;
193 }
194
DeleteLogger(Logger * logger)195 void DeleteLogger(Logger * logger)
196 {
197 if(logger)
198 delete logger;
199 }