Files
qt-creator/src/plugins/mercurial/mercurialeditor.cpp
2009-09-21 12:29:31 +03:00

86 lines
2.7 KiB
C++

#include "mercurialeditor.h"
#include "annotationhighlighter.h"
#include "constants.h"
#include "mercurialclient.h"
#include <coreplugin/editormanager/editormanager.h>
#include <vcsbase/diffhighlighter.h>
#include <QtCore/QSet>
#include <QtCore/QString>
#include <QtGui/QTextCursor>
#include <QtGui/QTextBlock>
#include <QtCore/QDir>
#include <QtCore/QDebug>
using namespace Mercurial::Internal;
using namespace Mercurial;
MercurialEditor::MercurialEditor(const VCSBase::VCSBaseEditorParameters *type, QWidget *parent)
: VCSBase::VCSBaseEditor(type, parent),
exactIdentifier12(Constants::CHANGEIDEXACT12),
exactIdentifier40(Constants::CHANGEIDEXACT40),
changesetIdentifier12(Constants::CHANGESETID12),
changesetIdentifier40(Constants::CHANGESETID40),
diffIdentifier(Constants::DIFFIDENTIFIER)
{
}
QSet<QString> MercurialEditor::annotationChanges() const
{
QSet<QString> changes;
const QString data = toPlainText();
if (data.isEmpty())
return changes;
int position = 0;
while ((position = changesetIdentifier12.indexIn(data, position)) != -1) {
changes.insert(changesetIdentifier12.cap(1));
position += changesetIdentifier12.matchedLength();
}
return changes;
}
QString MercurialEditor::changeUnderCursor(const QTextCursor &cursorIn) const
{
QTextCursor cursor = cursorIn;
cursor.select(QTextCursor::WordUnderCursor);
if (cursor.hasSelection()) {
const QString change = cursor.selectedText();
if (exactIdentifier12.exactMatch(change))
return change;
if (exactIdentifier40.exactMatch(change))
return change;
}
return QString();
}
VCSBase::DiffHighlighter *MercurialEditor::createDiffHighlighter() const
{
return new VCSBase::DiffHighlighter(diffIdentifier);
}
VCSBase::BaseAnnotationHighlighter *MercurialEditor::createAnnotationHighlighter(const QSet<QString> &changes) const
{
return new MercurialAnnotationHighlighter(changes);
}
QString MercurialEditor::fileNameFromDiffSpecification(const QTextBlock &diffFileSpec) const
{
QString filechangeId("+++ b/");
QTextBlock::iterator iterator;
for (iterator = diffFileSpec.begin(); !(iterator.atEnd()); iterator++) {
QTextFragment fragment = iterator.fragment();
if(fragment.isValid()) {
if (fragment.text().startsWith(filechangeId)) {
QFileInfo sourceFile(source());
QDir repository(MercurialClient::findTopLevelForFile(sourceFile));
QString filename = fragment.text().remove(0, filechangeId.size());
return repository.absoluteFilePath(filename);
}
}
}
return QString();
}