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
);
83 case DLL_PROCESS_DETACH
:
90 /***********************************************************************
91 * WerAddExcludedApplication (wer.@)
93 * Add an application to the user specific or the system wide exclusion list
96 * exeName [i] The application name
97 * allUsers [i] for all users (TRUE) or for the current user (FALSE)
101 * Failure: A HRESULT error code
104 HRESULT WINAPI
WerAddExcludedApplication(PCWSTR exeName
, BOOL allUsers
)
110 TRACE("(%s, %d)\n",debugstr_w(exeName
), allUsers
);
111 if (!exeName
|| !exeName
[0])
114 bs
= strrchrW(exeName
, '\\');
116 bs
++; /* skip the backslash */
121 bs
= (LPWSTR
) exeName
;
123 if (!RegCreateKeyW(allUsers
? HKEY_LOCAL_MACHINE
: HKEY_CURRENT_USER
, regpath_exclude
, &hkey
)) {
124 RegSetValueExW(hkey
, bs
, 0, REG_DWORD
, (LPBYTE
)&value
, sizeof(DWORD
));
128 return E_ACCESSDENIED
;
131 /***********************************************************************
132 * WerRemoveExcludedApplication (wer.@)
134 * remove an application from the exclusion list
137 * exeName [i] The application name
138 * allUsers [i] for all users (TRUE) or for the current user (FALSE)
142 * Failure: A HRESULT error code
145 HRESULT WINAPI
WerRemoveExcludedApplication(PCWSTR exeName
, BOOL allUsers
)
151 TRACE("(%s, %d)\n",debugstr_w(exeName
), allUsers
);
152 if (!exeName
|| !exeName
[0])
155 bs
= strrchrW(exeName
, '\\');
157 bs
++; /* skip the backslash */
162 bs
= (LPWSTR
) exeName
;
164 if (!RegCreateKeyW(allUsers
? HKEY_LOCAL_MACHINE
: HKEY_CURRENT_USER
, regpath_exclude
, &hkey
)) {
165 lres
= RegDeleteValueW(hkey
, bs
);
167 return lres
? __HRESULT_FROM_WIN32(ERROR_ENVVAR_NOT_FOUND
) : S_OK
;
169 return E_ACCESSDENIED
;
172 /***********************************************************************
173 * WerReportAddDump (wer.@)
175 * Add a dump of dumpType to hReportHandle.
178 * hReportHandle [i] error reporting handle to add the dump
179 * hProcess [i] handle to the regarding process
180 * hThread [o] handle to the regarding thread
181 * dumpType [i] type of the dump
182 * pExceptionParam [o] pointer to a WER_EXCEPTION_INFORMATION
183 * pDumpCustomOptions [o] pointer to a WER_DUMP_CUSTOM_OPTIONS
184 * dwFlags [i] flag to control the heap dump
188 * Failure: A HRESULT error code
191 HRESULT WINAPI
WerReportAddDump(HREPORT hReportHandle
, HANDLE hProcess
, HANDLE hThread
,
192 WER_DUMP_TYPE dumpType
, PWER_EXCEPTION_INFORMATION pExceptionParam
,
193 PWER_DUMP_CUSTOM_OPTIONS pDumpCustomOptions
, DWORD dwFlags
)
195 FIXME("(%p, %p, %p, %d, %p, %p, %u) :stub\n", hReportHandle
, hProcess
, hThread
, dumpType
,
196 pExceptionParam
, pDumpCustomOptions
, dwFlags
);
201 /***********************************************************************
202 * WerReportAddFile (wer.@)
204 * Add File to a error report handle.
207 * hreport [i] error reporting handle to add the file
208 * path [i] path to the file to add
209 * type [i] type of the file to add
210 * flags [i] flags for the file
214 * Failure: A HRESULT error code
217 HRESULT WINAPI
WerReportAddFile(HREPORT hreport
, PCWSTR path
, WER_FILE_TYPE type
, DWORD flags
)
219 FIXME("(%p, %s, %d, 0x%x) :stub\n", hreport
, debugstr_w(path
), type
, flags
);
224 /***********************************************************************
225 * WerReportCloseHandle (wer.@)
227 * Close an error reporting handle and free associated resources
230 * hreport [i] error reporting handle to close
234 * Failure: A HRESULT error code
237 HRESULT WINAPI
WerReportCloseHandle(HREPORT hreport
)
239 report_t
* report
= (report_t
*) hreport
;
243 TRACE("(%p)\n", hreport
);
244 EnterCriticalSection(&report_table_cs
);
246 LIST_FOR_EACH_ENTRY(cursor
, &report_table
, report_t
, entry
)
248 if (cursor
== report
) {
250 list_remove(&report
->entry
);
255 LeaveCriticalSection(&report_table_cs
);
264 /***********************************************************************
265 * WerReportCreate (wer.@)
267 * Create an error report in memory and return a related HANDLE
270 * eventtype [i] a name for the event type
271 * reporttype [i] what type of report should be created
272 * reportinfo [i] NULL or a ptr to a struct with some detailed information
273 * phandle [o] ptr, where the resulting handle should be saved
277 * Failure: A HRESULT error code
280 * The event type must be registered at microsoft. Predefined types are
281 * "APPCRASH" as the default on Windows, "Crash32" and "Crash64"
284 HRESULT WINAPI
WerReportCreate(PCWSTR eventtype
, WER_REPORT_TYPE reporttype
, PWER_REPORT_INFORMATION reportinfo
, HREPORT
*phandle
)
288 TRACE("(%s, %d, %p, %p)\n", debugstr_w(eventtype
), reporttype
, reportinfo
, phandle
);
290 TRACE(".wzFriendlyEventName: %s\n", debugstr_w(reportinfo
->wzFriendlyEventName
));
291 TRACE(".wzApplicationName: %s\n", debugstr_w(reportinfo
->wzApplicationName
));
294 if (phandle
) *phandle
= NULL
;
295 if (!eventtype
|| !eventtype
[0] || !phandle
) {
299 report
= heap_alloc_zero(FIELD_OFFSET(report_t
, eventtype
[lstrlenW(eventtype
) + 1]));
301 return __HRESULT_FROM_WIN32(ERROR_OUTOFMEMORY
);
303 lstrcpyW(report
->eventtype
, eventtype
);
304 report
->reporttype
= reporttype
;
307 report
->info
= *reportinfo
;
309 FIXME("build report information from scratch for %p\n", report
);
312 EnterCriticalSection(&report_table_cs
);
313 list_add_head(&report_table
, &report
->entry
);
314 LeaveCriticalSection(&report_table_cs
);
317 TRACE("=> %p\n", report
);
321 /***********************************************************************
322 * WerReportSetParameter (wer.@)
324 * Set one of 10 parameter / value pairs for a report handle
327 * hreport [i] error reporting handle to add the parameter
328 * id [i] parameter to set (WER_P0 up to WER_P9)
329 * name [i] optional name of the parameter
330 * value [i] value of the parameter
334 * Failure: A HRESULT error code
337 HRESULT WINAPI
WerReportSetParameter(HREPORT hreport
, DWORD id
, PCWSTR name
, PCWSTR value
)
339 FIXME("(%p, %d, %s, %s) :stub\n", hreport
, id
, debugstr_w(name
), debugstr_w(value
));
344 /***********************************************************************
345 * WerReportSubmit (wer.@)
347 * Ask the user for permission and send the error report
348 * then kill or restart the application, when requested
351 * hreport [i] error reporting handle to send
352 * consent [i] current transmit permission
353 * flags [i] flag to select dialog, transmission snd restart options
354 * presult [o] ptr, where the transmission result should be saved
358 * Failure: A HRESULT error code
361 HRESULT WINAPI
WerReportSubmit(HREPORT hreport
, WER_CONSENT consent
, DWORD flags
, PWER_SUBMIT_RESULT presult
)
363 FIXME("(%p, %d, 0x%x, %p) :stub\n", hreport
, consent
, flags
, presult
);
368 *presult
= WerDisabled
;
372 /***********************************************************************
373 * WerReportSetUIOption (wer.@)
375 HRESULT WINAPI
WerReportSetUIOption(HREPORT hreport
, WER_REPORT_UI uitype
, PCWSTR value
)
377 FIXME("(%p, %d, %s) :stub\n", hreport
, uitype
, debugstr_w(value
));