kde-workspace/drkonqi/debugger.cpp
2014-11-15 04:16:00 +02:00

147 lines
4.5 KiB
C++

/*
Copyright (C) 2009 George Kiagiadakis <gkiagia@users.sourceforge.net>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "debugger.h"
#include <KConfig>
#include <KConfigGroup>
#include <KGlobal>
#include <KStandardDirs>
#include <KMacroExpanderBase>
#include <KDebug>
#include "crashedapplication.h"
#include "drkonqi.h"
//static
QList<Debugger> Debugger::availableInternalDebuggers(const QString & backend)
{
return availableDebuggers("debuggers/internal/*", backend);
}
//static
QList<Debugger> Debugger::availableExternalDebuggers(const QString & backend)
{
return availableDebuggers("debuggers/external/*", backend);
}
bool Debugger::isValid() const
{
return !m_config.isNull();
}
bool Debugger::isInstalled() const
{
QString tryexec = tryExec();
return !tryexec.isEmpty() && !KStandardDirs::findExe(tryexec).isEmpty();
}
QString Debugger::name() const
{
return isValid() ? m_config->group("General").readEntry("Name") : QString();
}
QString Debugger::codeName() const
{
//fall back to the "TryExec" string if "CodeName" is not specified.
//for most debuggers those strings should be the same
return isValid() ? m_config->group("General").readEntry("CodeName", tryExec()) : QString();
}
QString Debugger::tryExec() const
{
return isValid() ? m_config->group("General").readEntry("TryExec") : QString();
}
QStringList Debugger::supportedBackends() const
{
return isValid() ? m_config->group("General").readEntry("Backends")
.split('|', QString::SkipEmptyParts) : QStringList();
}
void Debugger::setUsedBackend(const QString & backendName)
{
if (supportedBackends().contains(backendName)) {
m_backend = backendName;
}
}
QString Debugger::command() const
{
if (!isValid() || !m_config->hasGroup(m_backend)) {
return QString();
} else {
return m_config->group(m_backend).readPathEntry("Exec", QString());
}
}
QString Debugger::backtraceBatchCommands() const
{
if (!isValid() || !m_config->hasGroup(m_backend)) {
return QString();
} else {
return m_config->group(m_backend).readEntry("BatchCommands");
}
}
bool Debugger::runInTerminal() const
{
if (!isValid() || !m_config->hasGroup(m_backend)) {
return false;
} else {
return m_config->group(m_backend).readEntry("Terminal", false);
}
}
//static
void Debugger::expandString(QString & str, ExpandStringUsage usage, const QString & tempFile)
{
const CrashedApplication *appInfo = DrKonqi::crashedApplication();
QHash<QString, QString> map;
map[QLatin1String("progname")] = appInfo->name();
map[QLatin1String("execname")] = appInfo->fakeExecutableBaseName();
map[QLatin1String("execpath")] = appInfo->executable().absoluteFilePath();
map[QLatin1String("signum")] = QString::number(appInfo->signalNumber());
map[QLatin1String("signame")] = appInfo->signalName();
map[QLatin1String("pid")] = QString::number(appInfo->pid());
map[QLatin1String("tempfile")] = tempFile;
map[QLatin1String("thread")] = QString::number(appInfo->thread());
if (usage == ExpansionUsageShell) {
str = KMacroExpander::expandMacrosShellQuote(str, map);
} else {
str = KMacroExpander::expandMacros(str, map);
}
}
//static
QList<Debugger> Debugger::availableDebuggers(const char *regexp, const QString & backend)
{
KStandardDirs *dirs = KGlobal::dirs();
QStringList debuggers = dirs->findAllResources("appdata", QLatin1String(regexp),
KStandardDirs::NoDuplicates);
QList<Debugger> result;
foreach (const QString & debuggerFile, debuggers) {
Debugger debugger;
debugger.m_config = KSharedConfig::openConfig(debuggerFile);
if (debugger.supportedBackends().contains(backend)) {
debugger.setUsedBackend(backend);
result.append(debugger);
}
}
return result;
}