2 * Copyright 2010 Louis Lenders
3 * Copyright 2010 Detlef Riekenberg
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2.1 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
28 #include "wine/list.h"
29 #include "wine/unicode.h"
30 #include "wine/debug.h"
32 WINE_DEFAULT_DEBUG_CHANNEL(wer);
36 WER_REPORT_INFORMATION info;
37 WER_REPORT_TYPE reporttype;
42 static CRITICAL_SECTION report_table_cs;
43 static CRITICAL_SECTION_DEBUG report_table_cs_debug =
45 0, 0, &report_table_cs,
46 { &report_table_cs_debug.ProcessLocksList, &report_table_cs_debug.ProcessLocksList },
47 0, 0, { (DWORD_PTR)(__FILE__ ": report_table_cs") }
49 static CRITICAL_SECTION report_table_cs = { &report_table_cs_debug, -1, 0, 0, 0, 0 };
51 static struct list report_table = LIST_INIT(report_table);
53 static WCHAR regpath_exclude[] = {'S','o','f','t','w','a','r','e','\\',
54 'M','i','c','r','o','s','o','f','t','\\',
55 'W','i','n','d','o','w','s',' ','E','r','r','o','r',' ','R','e','p','o','r','t','i','n','g','\\',
56 'E','x','c','l','u','d','e','d','A','p','p','l','i','c','a','t','i','o','n','s',0};
58 /***********************************************************************
59 * Memory allocation helper
62 static inline void * __WINE_ALLOC_SIZE(1) heap_alloc_zero(size_t len)
64 return HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, len);
67 static inline BOOL heap_free(void *mem)
69 return HeapFree(GetProcessHeap(), 0, mem);
72 BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
74 TRACE("(0x%p, %d, %p)\n", hinstDLL, fdwReason, lpvReserved);
78 case DLL_WINE_PREATTACH:
79 return FALSE; /* prefer native version */
80 case DLL_PROCESS_ATTACH:
81 DisableThreadLibraryCalls(hinstDLL);
88 /***********************************************************************
89 * WerAddExcludedApplication (wer.@)
91 * Add an application to the user specific or the system wide exclusion list
94 * exeName [i] The application name
95 * allUsers [i] for all users (TRUE) or for the current user (FALSE)
99 * Failure: A HRESULT error code
102 HRESULT WINAPI WerAddExcludedApplication(PCWSTR exeName, BOOL allUsers)
108 TRACE("(%s, %d)\n",debugstr_w(exeName), allUsers);
109 if (!exeName || !exeName[0])
112 bs = strrchrW(exeName, '\\');
114 bs++; /* skip the backslash */
119 bs = (LPWSTR) exeName;
121 if (!RegCreateKeyW(allUsers ? HKEY_LOCAL_MACHINE : HKEY_CURRENT_USER, regpath_exclude, &hkey)) {
122 RegSetValueExW(hkey, bs, 0, REG_DWORD, (LPBYTE)&value, sizeof(DWORD));
126 return E_ACCESSDENIED;
129 /***********************************************************************
130 * WerRemoveExcludedApplication (wer.@)
132 * remove an application from the exclusion list
135 * exeName [i] The application name
136 * allUsers [i] for all users (TRUE) or for the current user (FALSE)
140 * Failure: A HRESULT error code
143 HRESULT WINAPI WerRemoveExcludedApplication(PCWSTR exeName, BOOL allUsers)
149 TRACE("(%s, %d)\n",debugstr_w(exeName), allUsers);
150 if (!exeName || !exeName[0])
153 bs = strrchrW(exeName, '\\');
155 bs++; /* skip the backslash */
160 bs = (LPWSTR) exeName;
162 if (!RegCreateKeyW(allUsers ? HKEY_LOCAL_MACHINE : HKEY_CURRENT_USER, regpath_exclude, &hkey)) {
163 lres = RegDeleteValueW(hkey, bs);
165 return lres ? __HRESULT_FROM_WIN32(ERROR_ENVVAR_NOT_FOUND) : S_OK;
167 return E_ACCESSDENIED;
170 /***********************************************************************
171 * WerReportAddDump (wer.@)
173 * Add a dump of dumpType to hReportHandle.
176 * hReportHandle [i] error reporting handle to add the dump
177 * hProcess [i] handle to the regarding process
178 * hThread [o] handle to the regarding thread
179 * dumpType [i] type of the dump
180 * pExceptionParam [o] pointer to a WER_EXCEPTION_INFORMATION
181 * pDumpCustomOptions [o] pointer to a WER_DUMP_CUSTOM_OPTIONS
182 * dwFlags [i] flag to control the heap dump
186 * Failure: A HRESULT error code
189 HRESULT WINAPI WerReportAddDump(HREPORT hReportHandle, HANDLE hProcess, HANDLE hThread,
190 WER_DUMP_TYPE dumpType, PWER_EXCEPTION_INFORMATION pExceptionParam,
191 PWER_DUMP_CUSTOM_OPTIONS pDumpCustomOptions, DWORD dwFlags)
193 FIXME("(%p, %p, %p, %d, %p, %p, %u) :stub\n", hReportHandle, hProcess, hThread, dumpType,
194 pExceptionParam, pDumpCustomOptions, dwFlags);
199 /***********************************************************************
200 * WerReportAddFile (wer.@)
202 * Add File to a error report handle.
205 * hreport [i] error reporting handle to add the file
206 * path [i] path to the file to add
207 * type [i] type of the file to add
208 * flags [i] flags for the file
212 * Failure: A HRESULT error code
215 HRESULT WINAPI WerReportAddFile(HREPORT hreport, PCWSTR path, WER_FILE_TYPE type, DWORD flags)
217 FIXME("(%p, %s, %d, 0x%x) :stub\n", hreport, debugstr_w(path), type, flags);
222 /***********************************************************************
223 * WerReportCloseHandle (wer.@)
225 * Close an error reporting handle and free associated resources
228 * hreport [i] error reporting handle to close
232 * Failure: A HRESULT error code
235 HRESULT WINAPI WerReportCloseHandle(HREPORT hreport)
237 report_t * report = (report_t *) hreport;
241 TRACE("(%p)\n", hreport);
242 EnterCriticalSection(&report_table_cs);
244 LIST_FOR_EACH_ENTRY(cursor, &report_table, report_t, entry)
246 if (cursor == report) {
248 list_remove(&report->entry);
253 LeaveCriticalSection(&report_table_cs);
262 /***********************************************************************
263 * WerReportCreate (wer.@)
265 * Create an error report in memory and return a related HANDLE
268 * eventtype [i] a name for the event type
269 * reporttype [i] what type of report should be created
270 * reportinfo [i] NULL or a ptr to a struct with some detailed information
271 * phandle [o] ptr, where the resulting handle should be saved
275 * Failure: A HRESULT error code
278 * The event type must be registered at microsoft. Predefined types are
279 * "APPCRASH" as the default on Windows, "Crash32" and "Crash64"
282 HRESULT WINAPI WerReportCreate(PCWSTR eventtype, WER_REPORT_TYPE reporttype, PWER_REPORT_INFORMATION reportinfo, HREPORT *phandle)
286 TRACE("(%s, %d, %p, %p)\n", debugstr_w(eventtype), reporttype, reportinfo, phandle);
288 TRACE(".wzFriendlyEventName: %s\n", debugstr_w(reportinfo->wzFriendlyEventName));
289 TRACE(".wzApplicationName: %s\n", debugstr_w(reportinfo->wzApplicationName));
292 if (phandle) *phandle = NULL;
293 if (!eventtype || !eventtype[0] || !phandle) {
297 report = heap_alloc_zero(FIELD_OFFSET(report_t, eventtype[lstrlenW(eventtype) + 1]));
299 return __HRESULT_FROM_WIN32(ERROR_OUTOFMEMORY);
301 lstrcpyW(report->eventtype, eventtype);
302 report->reporttype = reporttype;
305 report->info = *reportinfo;
307 FIXME("build report information from scratch for %p\n", report);
310 EnterCriticalSection(&report_table_cs);
311 list_add_head(&report_table, &report->entry);
312 LeaveCriticalSection(&report_table_cs);
315 TRACE("=> %p\n", report);
319 /***********************************************************************
320 * WerReportSetParameter (wer.@)
322 * Set one of 10 parameter / value pairs for a report handle
325 * hreport [i] error reporting handle to add the parameter
326 * id [i] parameter to set (WER_P0 up to WER_P9)
327 * name [i] optional name of the parameter
328 * value [i] value of the parameter
332 * Failure: A HRESULT error code
335 HRESULT WINAPI WerReportSetParameter(HREPORT hreport, DWORD id, PCWSTR name, PCWSTR value)
337 FIXME("(%p, %d, %s, %s) :stub\n", hreport, id, debugstr_w(name), debugstr_w(value));
342 /***********************************************************************
343 * WerReportSubmit (wer.@)
345 * Ask the user for permission and send the error report
346 * then kill or restart the application, when requested
349 * hreport [i] error reporting handle to send
350 * consent [i] current transmit permission
351 * flags [i] flag to select dialog, transmission snd restart options
352 * presult [o] ptr, where the transmission result should be saved
356 * Failure: A HRESULT error code
359 HRESULT WINAPI WerReportSubmit(HREPORT hreport, WER_CONSENT consent, DWORD flags, PWER_SUBMIT_RESULT presult)
361 FIXME("(%p, %d, 0x%x, %p) :stub\n", hreport, consent, flags, presult);
366 *presult = WerDisabled;
370 /***********************************************************************
371 * WerReportSetUIOption (wer.@)
373 HRESULT WINAPI WerReportSetUIOption(HREPORT hreport, WER_REPORT_UI uitype, PCWSTR value)
375 FIXME("(%p, %d, %s) :stub\n", hreport, uitype, debugstr_w(value));