(→Debugging kioslaves: improved) |
(→Debugging kioslaves) |
||
| Line 7: | Line 7: | ||
kioslaves on windows are started by klauncher (or kio) as separate kioslave processes. The kioslave executable then loads the related kioslave dll dynamically. | kioslaves on windows are started by klauncher (or kio) as separate kioslave processes. The kioslave executable then loads the related kioslave dll dynamically. | ||
| − | To debug kioslaves | + | To debug kioslaves: |
| − | #set the KDE_SLAVE_DEBUG_WAIT environment variable to the name of the kioslave's protocol (the first parameter of KIO::SlaveBase() constructor) | + | #set the KDE_SLAVE_DEBUG_WAIT environment variable to the name of the kioslave's protocol (the first parameter of KIO::SlaveBase() constructor), |
| − | #restart klauncher | + | #restart klauncher. |
{{Note|For example, set the variable to 'file' for the kio_file slave, '''but''' set it to 'smtps' for the kio_smtp is you want to debug smtp protocol secured with SSL.}} | {{Note|For example, set the variable to 'file' for the kio_file slave, '''but''' set it to 'smtps' for the kio_smtp is you want to debug smtp protocol secured with SSL.}} | ||
Contents |
Debug messages (logs) generated by kDebug() and kWarning() are not visible on MS Windows unless application is compiled in so-called CONSOLE subsystem. To show these messages also in WINDOWS subsystem, you can use DebugView tool, coming from SysInternals (currently acquired by Microsoft). The tool offers searching in logs, filtering and saving them to file.
kioslaves on windows are started by klauncher (or kio) as separate kioslave processes. The kioslave executable then loads the related kioslave dll dynamically.
To debug kioslaves:
| Note |
|---|
| For example, set the variable to 'file' for the kio_file slave, but set it to 'smtps' for the kio_smtp is you want to debug smtp protocol secured with SSL. |
If the requested kioslave is requested the next time, a debugger will be started and attached to the kioslave process immediatly before the kioslave's kdemain() function.
On mingw platform gdb is launched and connected to the kioslave process. On msvc platforms the currently installed just-in-time debugger is used. This may be msvc's IDE or the windbg debugger. The latter could be set as jit-debugger by running 'windbg -I' command.
You may inspect kioslave sources [1] for more informations.
Let's assume you're using command line tools (typically SCons) and want to use MS Visual Studio environment for just debugging. You don't need to create msvc project for your KDE application to be able to start debugging.
If you have your application is already running, you can attach to it and then start debugging.
You can create a macro that automates the task. See [2].
If you are using the debug heap, memory is initialized and cleared with special values. Most interesting values are:
See also: [3]
You'll probably want to avoind stepping into lower-level functions like QString constructors or operators while debugging step-by-step. Here's the detailed (unofficial) instruction for various msvc versions.