forked from qt-creator/qt-creator
VcsCommandPage: Handle extra setup steps after checkout
Change-Id: I3b0aea8edaeddad7ee6d2424b31c3c234f6df0cd Reviewed-by: Orgad Shaneh <orgads@gmail.com>
This commit is contained in:
@@ -56,6 +56,14 @@ static char VCSCOMMAND_DIR[] = "baseDirectory";
|
|||||||
static char VCSCOMMAND_EXTRA_ARGS[] = "extraArguments";
|
static char VCSCOMMAND_EXTRA_ARGS[] = "extraArguments";
|
||||||
static char VCSCOMMAND_CHECKOUTNAME[] = "checkoutName";
|
static char VCSCOMMAND_CHECKOUTNAME[] = "checkoutName";
|
||||||
|
|
||||||
|
static char VCSCOMMAND_JOBS[] = "extraJobs";
|
||||||
|
static char JOB_SKIP_EMPTY[] = "skipIfEmpty";
|
||||||
|
static char JOB_WORK_DIRECTORY[] = "directory";
|
||||||
|
static char JOB_COMMAND[] = "command";
|
||||||
|
static char JOB_ARGUMENTS[] = "arguments";
|
||||||
|
static char JOB_TIME_OUT[] = "timeoutFactor";
|
||||||
|
static char JOB_ENABLED[] = "enabled";
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
// VcsCommandPageFactory:
|
// VcsCommandPageFactory:
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
@@ -97,6 +105,38 @@ Utils::WizardPage *VcsCommandPageFactory::create(JsonWizard *wizard, Id typeId,
|
|||||||
tmp.value(QLatin1String(VCSCOMMAND_CHECKOUTNAME)).toString(),
|
tmp.value(QLatin1String(VCSCOMMAND_CHECKOUTNAME)).toString(),
|
||||||
args);
|
args);
|
||||||
|
|
||||||
|
foreach (const QVariant &value, tmp.value(QLatin1String(VCSCOMMAND_JOBS)).toList()) {
|
||||||
|
const QVariantMap job = value.toMap();
|
||||||
|
const bool skipEmpty = job.value(QLatin1String(JOB_SKIP_EMPTY), true).toBool();
|
||||||
|
const QString workDir = job.value(QLatin1String(JOB_WORK_DIRECTORY)).toString();
|
||||||
|
|
||||||
|
const QString cmdString = job.value(QLatin1String(JOB_COMMAND)).toString();
|
||||||
|
QTC_ASSERT(!cmdString.isEmpty(), continue);
|
||||||
|
|
||||||
|
QStringList command;
|
||||||
|
command << cmdString;
|
||||||
|
|
||||||
|
const QVariant &jobArgVar = job.value(QLatin1String(JOB_ARGUMENTS));
|
||||||
|
QStringList jobArgs;
|
||||||
|
if (!jobArgVar.isNull()) {
|
||||||
|
if (jobArgVar.type() == QVariant::List)
|
||||||
|
jobArgs = Utils::transform(jobArgVar.toList(), &QVariant::toString);
|
||||||
|
else
|
||||||
|
jobArgs << jobArgVar.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ok;
|
||||||
|
int timeoutFactor = job.value(QLatin1String(JOB_TIME_OUT), 1).toInt(&ok);
|
||||||
|
if (!ok)
|
||||||
|
timeoutFactor = 1;
|
||||||
|
|
||||||
|
command << jobArgs;
|
||||||
|
|
||||||
|
const QVariant condition = job.value(QLatin1String(JOB_ENABLED), true);
|
||||||
|
|
||||||
|
page->appendJob(skipEmpty, workDir, command, condition, timeoutFactor);
|
||||||
|
}
|
||||||
|
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -143,6 +183,28 @@ bool VcsCommandPageFactory::validateData(Id typeId, const QVariant &data, QStrin
|
|||||||
em = tr("\"%1\" in \"data\" section of \"VcsCommand\" page has unexpected type (unset, String or List).")
|
em = tr("\"%1\" in \"data\" section of \"VcsCommand\" page has unexpected type (unset, String or List).")
|
||||||
.arg(QLatin1String(VCSCOMMAND_EXTRA_ARGS));
|
.arg(QLatin1String(VCSCOMMAND_EXTRA_ARGS));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const QVariant jobs = tmp.value(QLatin1String(VCSCOMMAND_JOBS));
|
||||||
|
if (!jobs.isNull() && extra.type() != QVariant::List) {
|
||||||
|
em = tr("\"%1\" in \"data\" section of \"VcsCommand\" page has unexpected type (unset or List).")
|
||||||
|
.arg(QLatin1String(VCSCOMMAND_JOBS));
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (const QVariant &j, jobs.toList()) {
|
||||||
|
if (j.isNull()) {
|
||||||
|
em = tr("Job in \"VcsCommand\" page is empty.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (j.type() != QVariant::Map) {
|
||||||
|
em = tr("Job in \"VcsCommand\" page is not an object.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
const QVariantMap &details = j.toMap();
|
||||||
|
if (details.value(QLatin1String(JOB_COMMAND)).isNull()) {
|
||||||
|
em = tr("Job in \"VcsCommand\" page has no \"%1\" set.").arg(QLatin1String(JOB_COMMAND));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (errorMessage)
|
if (errorMessage)
|
||||||
@@ -234,6 +296,30 @@ void VcsCommandPage::delayedInitialize()
|
|||||||
ShellCommand *command
|
ShellCommand *command
|
||||||
= vc->createInitialCheckoutCommand(repo, Utils::FileName::fromString(base),
|
= vc->createInitialCheckoutCommand(repo, Utils::FileName::fromString(base),
|
||||||
name, extraArgs);
|
name, extraArgs);
|
||||||
|
|
||||||
|
foreach (const JobData &job, m_additionalJobs) {
|
||||||
|
QTC_ASSERT(!job.job.isEmpty(), continue);
|
||||||
|
|
||||||
|
if (!JsonWizard::boolFromVariant(job.condition, wiz->expander()))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
QString commandString = wiz->expander()->expand(job.job.at(0));
|
||||||
|
if (commandString.isEmpty())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
QStringList args;
|
||||||
|
for (int i = 1; i < job.job.count(); ++i) {
|
||||||
|
const QString tmp = wiz->expander()->expand(job.job.at(i));
|
||||||
|
if (tmp.isEmpty() && job.skipEmptyArguments)
|
||||||
|
continue;
|
||||||
|
args << tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
const QString dir = wiz->expander()->expand(job.workDirectory);
|
||||||
|
const int timeoutS = command->defaultTimeoutS() * job.timeOutFactor;
|
||||||
|
command->addJob(Utils::FileName::fromUserInput(commandString), args, timeoutS, dir);
|
||||||
|
}
|
||||||
|
|
||||||
start(command);
|
start(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -246,9 +332,10 @@ void VcsCommandPage::setCheckoutData(const QString &repo, const QString &baseDir
|
|||||||
m_arguments = args;
|
m_arguments = args;
|
||||||
}
|
}
|
||||||
|
|
||||||
void VcsCommandPage::appendJob(bool skip, const QStringList &command)
|
void VcsCommandPage::appendJob(bool skipEmpty, const QString &workDir, const QStringList &command,
|
||||||
|
const QVariant &condition, int timeoutFactor)
|
||||||
{
|
{
|
||||||
m_additionalJobs.append(JobData(skip, command));
|
m_additionalJobs.append(JobData(skipEmpty, workDir, command, condition, timeoutFactor));
|
||||||
}
|
}
|
||||||
|
|
||||||
void VcsCommandPage::setVersionControlId(const QString &id)
|
void VcsCommandPage::setVersionControlId(const QString &id)
|
||||||
|
|||||||
@@ -65,7 +65,8 @@ public:
|
|||||||
|
|
||||||
void setCheckoutData(const QString &repo, const QString &baseDir, const QString &name,
|
void setCheckoutData(const QString &repo, const QString &baseDir, const QString &name,
|
||||||
const QStringList &args);
|
const QStringList &args);
|
||||||
void appendJob(bool skip, const QStringList &command);
|
void appendJob(bool skipEmpty, const QString &workDir, const QStringList &command,
|
||||||
|
const QVariant &condition, int timeoutFactor);
|
||||||
void setVersionControlId(const QString &id);
|
void setVersionControlId(const QString &id);
|
||||||
void setRunMessage(const QString &msg);
|
void setRunMessage(const QString &msg);
|
||||||
|
|
||||||
@@ -81,8 +82,14 @@ private:
|
|||||||
QStringList m_arguments;
|
QStringList m_arguments;
|
||||||
|
|
||||||
struct JobData {
|
struct JobData {
|
||||||
JobData(bool s, const QStringList &c) : job(c), skipEmptyArguments(s) { }
|
JobData(bool s, const QString &wd, const QStringList &c, const QVariant &cnd, int toF) :
|
||||||
|
workDirectory(wd), job(c), condition(cnd), timeOutFactor(toF), skipEmptyArguments(s)
|
||||||
|
{ }
|
||||||
|
|
||||||
|
QString workDirectory;
|
||||||
QStringList job;
|
QStringList job;
|
||||||
|
QVariant condition;
|
||||||
|
int timeOutFactor;
|
||||||
bool skipEmptyArguments = false;
|
bool skipEmptyArguments = false;
|
||||||
};
|
};
|
||||||
QList<JobData> m_additionalJobs;
|
QList<JobData> m_additionalJobs;
|
||||||
|
|||||||
Reference in New Issue
Block a user