1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
/*
SPDX-FileCopyrightText: 2014 Kevin Funk <kfunk@kde.org>
SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL
*/
#include "clangdebug.h"
#include "clangtypes.h"
#include <language/editor/documentcursor.h>
#include <language/editor/documentrange.h>
// Keep in sync with declare_qt_logging_category call
const QtMsgType defaultMsgType = QtInfoMsg;
Q_LOGGING_CATEGORY(KDEV_CLANG, "kdevelop.plugins.clang", defaultMsgType)
using namespace KDevelop;
QDebug operator<<(QDebug dbg, CXString string)
{
dbg << ClangString(string).c_str();
return dbg;
}
QDebug operator<<(QDebug dbg, CXSourceLocation location)
{
dbg << DocumentCursor(ClangLocation(location));
return dbg;
}
QDebug operator<<(QDebug dbg, CXSourceRange range)
{
dbg << ClangRange(range).toDocumentRange();
return dbg;
}
QDebug operator<<(QDebug dbg, CXCursor cursor)
{
return dbg << clang_getCursorKind(cursor) << clang_getCursorDisplayName(cursor) << clang_getCursorType(cursor) << clang_getCursorLocation(cursor);
}
QDebug operator<<(QDebug dbg, CXCursorKind kind)
{
return dbg << clang_getCursorKindSpelling(kind);
}
QDebug operator<<(QDebug dbg, CXType type)
{
return dbg << type.kind << clang_getTypeSpelling(type);
}
QDebug operator<<(QDebug dbg, CXTypeKind typeKind)
{
return dbg << clang_getTypeKindSpelling(typeKind);
}
|