forked from qt-creator/qt-creator
Git: Add dialog to configure branches
This commit is contained in:
232
src/plugins/git/remotemodel.cpp
Normal file
232
src/plugins/git/remotemodel.cpp
Normal file
@@ -0,0 +1,232 @@
|
||||
/**************************************************************************
|
||||
**
|
||||
** This file is part of Qt Creator
|
||||
**
|
||||
** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
|
||||
**
|
||||
** Contact: Nokia Corporation (info@qt.nokia.com)
|
||||
**
|
||||
**
|
||||
** GNU Lesser General Public License Usage
|
||||
**
|
||||
** This file may be used under the terms of the GNU Lesser General Public
|
||||
** License version 2.1 as published by the Free Software Foundation and
|
||||
** appearing in the file LICENSE.LGPL included in the packaging of this file.
|
||||
** Please review the following information to ensure the GNU Lesser General
|
||||
** Public License version 2.1 requirements will be met:
|
||||
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
||||
**
|
||||
** In addition, as a special exception, Nokia gives you certain additional
|
||||
** rights. These rights are described in the Nokia Qt LGPL Exception
|
||||
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
||||
**
|
||||
** Other Usage
|
||||
**
|
||||
** Alternatively, this file may be used in accordance with the terms and
|
||||
** conditions contained in a signed written agreement between you and Nokia.
|
||||
**
|
||||
** If you have questions regarding the use of this file, please contact
|
||||
** Nokia at info@qt.nokia.com.
|
||||
**
|
||||
**************************************************************************/
|
||||
|
||||
#include "remotemodel.h"
|
||||
#include "gitclient.h"
|
||||
|
||||
namespace Git {
|
||||
namespace Internal {
|
||||
|
||||
// Parse a branch line: " *name sha description".
|
||||
bool RemoteModel::Remote::parse(const QString &line)
|
||||
{
|
||||
if (!line.endsWith(" (fetch)"))
|
||||
return false;
|
||||
|
||||
QStringList tokens = line.split(QRegExp("\\s"), QString::SkipEmptyParts);
|
||||
if (tokens.count() != 3)
|
||||
return false;
|
||||
|
||||
name = tokens.at(0);
|
||||
url = tokens.at(1);
|
||||
return true;
|
||||
}
|
||||
|
||||
// ------ RemoteModel
|
||||
RemoteModel::RemoteModel(GitClient *client, QObject *parent) :
|
||||
QAbstractTableModel(parent),
|
||||
m_flags(Qt::ItemIsSelectable|Qt::ItemIsEnabled|Qt::ItemIsEditable),
|
||||
m_client(client)
|
||||
{ }
|
||||
|
||||
bool RemoteModel::refresh(const QString &workingDirectory, QString *errorMessage)
|
||||
{
|
||||
return refreshRemotes(workingDirectory, errorMessage);
|
||||
}
|
||||
|
||||
QString RemoteModel::remoteName(int row) const
|
||||
{
|
||||
return m_remotes.at(row).name;
|
||||
}
|
||||
|
||||
QString RemoteModel::remoteUrl(int row) const
|
||||
{
|
||||
return m_remotes.at(row).url;
|
||||
}
|
||||
|
||||
bool RemoteModel::removeRemote(int row)
|
||||
{
|
||||
QString output;
|
||||
QString error;
|
||||
bool success = runGitRemoteCommand(m_workingDirectory,
|
||||
QStringList() << QLatin1String("rm") << remoteName(row),
|
||||
&output, &error);
|
||||
if (success)
|
||||
success = refreshRemotes(m_workingDirectory, &error);
|
||||
return success;
|
||||
}
|
||||
|
||||
bool RemoteModel::addRemote(const QString &name, const QString &url)
|
||||
{
|
||||
QString output;
|
||||
QString error;
|
||||
if (name.isEmpty() || url.isEmpty())
|
||||
return false;
|
||||
|
||||
bool success = runGitRemoteCommand(m_workingDirectory,
|
||||
QStringList() << QLatin1String("add") << name << url,
|
||||
&output, &error);
|
||||
if (success)
|
||||
success = refreshRemotes(m_workingDirectory, &error);
|
||||
return success;
|
||||
}
|
||||
|
||||
bool RemoteModel::renameRemote(const QString &oldName, const QString &newName)
|
||||
{
|
||||
QString output;
|
||||
QString error;
|
||||
bool success = runGitRemoteCommand(m_workingDirectory,
|
||||
QStringList() << QLatin1String("rename") << oldName << newName,
|
||||
&output, &error);
|
||||
if (success)
|
||||
success = refreshRemotes(m_workingDirectory, &error);
|
||||
return success;
|
||||
}
|
||||
|
||||
bool RemoteModel::updateUrl(const QString &name, const QString &newUrl)
|
||||
{
|
||||
QString output;
|
||||
QString error;
|
||||
bool success = runGitRemoteCommand(m_workingDirectory,
|
||||
QStringList() << QLatin1String("set-url") << name << newUrl,
|
||||
&output, &error);
|
||||
if (success)
|
||||
success = refreshRemotes(m_workingDirectory, &error);
|
||||
return success;
|
||||
}
|
||||
|
||||
QString RemoteModel::workingDirectory() const
|
||||
{
|
||||
return m_workingDirectory;
|
||||
}
|
||||
|
||||
int RemoteModel::remoteCount() const
|
||||
{
|
||||
return m_remotes.size();
|
||||
}
|
||||
|
||||
int RemoteModel::rowCount(const QModelIndex &parent) const
|
||||
{
|
||||
Q_UNUSED(parent);
|
||||
return remoteCount();
|
||||
}
|
||||
|
||||
int RemoteModel::columnCount(const QModelIndex &parent) const
|
||||
{
|
||||
Q_UNUSED(parent);
|
||||
return 2;
|
||||
}
|
||||
|
||||
QVariant RemoteModel::data(const QModelIndex &index, int role) const
|
||||
{
|
||||
const int row = index.row();
|
||||
switch (role) {
|
||||
case Qt::DisplayRole:
|
||||
case Qt::EditRole:
|
||||
if (index.column() == 0)
|
||||
return remoteName(row);
|
||||
else
|
||||
return remoteUrl(row);
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return QVariant();
|
||||
}
|
||||
|
||||
bool RemoteModel::setData(const QModelIndex &index, const QVariant &value, int role)
|
||||
{
|
||||
if (role != Qt::EditRole)
|
||||
return false;
|
||||
|
||||
const QString name = remoteName(index.row());
|
||||
switch (index.column()) {
|
||||
case 0:
|
||||
return renameRemote(name, value.toString());
|
||||
case 1:
|
||||
return updateUrl(name, value.toString());
|
||||
default:
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
Qt::ItemFlags RemoteModel::flags(const QModelIndex &index) const
|
||||
{
|
||||
Q_UNUSED(index);
|
||||
return m_flags;
|
||||
}
|
||||
|
||||
bool RemoteModel::runGitRemoteCommand(const QString &workingDirectory, const QStringList &additionalArgs, QString *output, QString *errorMessage)
|
||||
{
|
||||
return m_client->synchronousRemoteCmd(workingDirectory, additionalArgs, output, errorMessage);
|
||||
}
|
||||
|
||||
void RemoteModel::clear()
|
||||
{
|
||||
if (m_remotes.isEmpty())
|
||||
return;
|
||||
m_remotes.clear();
|
||||
reset();
|
||||
}
|
||||
|
||||
bool RemoteModel::refreshRemotes(const QString &workingDirectory, QString *errorMessage)
|
||||
{
|
||||
// Run branch command with verbose.
|
||||
QStringList remoteArgs;
|
||||
remoteArgs << QLatin1String("-v");
|
||||
QString output;
|
||||
if (!runGitRemoteCommand(workingDirectory, remoteArgs, &output, errorMessage))
|
||||
return false;
|
||||
// Parse output
|
||||
m_workingDirectory = workingDirectory;
|
||||
m_remotes.clear();
|
||||
const QStringList lines = output.split(QLatin1Char('\n'));
|
||||
for (int r = 0; r < lines.count(); ++r) {
|
||||
Remote newRemote;
|
||||
if (newRemote.parse(lines.at(r)))
|
||||
m_remotes.push_back(newRemote);
|
||||
}
|
||||
reset();
|
||||
return true;
|
||||
}
|
||||
|
||||
int RemoteModel::findRemoteByName(const QString &name) const
|
||||
{
|
||||
const int count = remoteCount();
|
||||
for (int i = 0; i < count; i++)
|
||||
if (remoteName(i) == name)
|
||||
return i;
|
||||
return -1;
|
||||
}
|
||||
|
||||
} // namespace Internal
|
||||
} // namespace Git
|
||||
|
||||
Reference in New Issue
Block a user