Newer
Older
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
57
58
59
60
61
62
63
64
65
66
67
68
#include "commiteditor.h"
#include "mercurialcommitwidget.h"
#include <vcsbase/submitfilemodel.h>
#include <QtCore/QDebug>
#include <QDir> //TODO REMOVE WHEN BASE FILE CHANGES ARE PULLED
using namespace Mercurial::Internal;
CommitEditor::CommitEditor(const VCSBase::VCSBaseSubmitEditorParameters *parameters, QWidget *parent)
: VCSBase::VCSBaseSubmitEditor(parameters, new MercurialCommitWidget(parent)),
fileModel(0)
{
setDisplayName(tr("Commit Editor"));
}
MercurialCommitWidget *CommitEditor::commitWidget()
{
return static_cast<MercurialCommitWidget *>(widget());
}
void CommitEditor::setFields(const QFileInfo &repositoryRoot, const QString &branch,
const QString &userName, const QString &email,
const QList<QPair<QString, QString> > &repoStatus)
{
MercurialCommitWidget *mercurialWidget = commitWidget();
if (!mercurialWidget)
return;
mercurialWidget->setFields(repositoryRoot.absoluteFilePath(), branch, userName, email);
fileModel = new VCSBase::SubmitFileModel(this);
//TODO Messy tidy this up
typedef QPair<QString, QString> PAIR;
QStringList shouldTrack;
foreach (PAIR status, repoStatus) {
if (status.first == "Untracked")
shouldTrack.append(status.second);
else
fileModel->addFile(status.second, status.first, false);
}
VCSBase::VCSBaseSubmitEditor::filterUntrackedFilesOfProject(repositoryRoot.absoluteFilePath(),
&shouldTrack);
foreach (QString track, shouldTrack) {
foreach (PAIR status, repoStatus) {
if (status.second == track)
fileModel->addFile(status.second, status.first, false);
}
}
setFileModel(fileModel);
}
QString CommitEditor::committerInfo()
{
return commitWidget()->committer();
}
QString CommitEditor::repoRoot()
{
return commitWidget()->repoRoot();
}