forked from qt-creator/qt-creator
QTBUG-28385 is biting us over and over (QWizard doesn't have close button nor cancel button on Mac in Qt 5), and actually there's no reason for us having a wizard without the features from Utils::Wizard. Task-number: QTCREATORBUG-10346 Task-number: QTBUG-28385 Change-Id: I80c0d82fe6738496c2ac03c31a1c2757ade8e266 Reviewed-by: Jarek Kobus <jaroslaw.kobus@digia.com> Reviewed-by: Daniel Teske <daniel.teske@digia.com>
111 lines
3.9 KiB
C++
111 lines
3.9 KiB
C++
/**************************************************************************
|
|
**
|
|
** Copyright (C) 2013 Openismus GmbH.
|
|
** Authors: Peter Penz (ppenz@openismus.com)
|
|
** Patricia Santana Cruz (patriciasantanacruz@gmail.com)
|
|
** Contact: http://www.qt-project.org/legal
|
|
**
|
|
** This file is part of Qt Creator.
|
|
**
|
|
** Commercial License Usage
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
** accordance with the commercial license agreement provided with the
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
** a written agreement between you and Digia. For licensing terms and
|
|
** conditions see http://qt.digia.com/licensing. For further information
|
|
** use the contact form at http://qt.digia.com/contact-us.
|
|
**
|
|
** GNU Lesser General Public License Usage
|
|
** Alternatively, 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, Digia gives you certain additional
|
|
** rights. These rights are described in the Digia Qt LGPL Exception
|
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
**
|
|
****************************************************************************/
|
|
|
|
#include "autotoolsopenprojectwizard.h"
|
|
|
|
#include <utils/pathchooser.h>
|
|
|
|
#include <QVBoxLayout>
|
|
#include <QFormLayout>
|
|
#include <QLabel>
|
|
#include <QDir>
|
|
|
|
using namespace AutotoolsProjectManager;
|
|
using namespace AutotoolsProjectManager::Internal;
|
|
|
|
//////////////////////////////////////
|
|
// AutotoolsOpenProjectWizard class
|
|
//////////////////////////////////////
|
|
AutotoolsOpenProjectWizard::AutotoolsOpenProjectWizard(AutotoolsManager *manager,
|
|
const QString &sourceDirectory,
|
|
QWidget *parent)
|
|
: Utils::Wizard(parent),
|
|
m_manager(manager),
|
|
m_sourceDirectory(sourceDirectory)
|
|
{
|
|
QDir dir(m_sourceDirectory);
|
|
m_buildDirectory = dir.absolutePath();
|
|
|
|
setPage(BuildPathPageId, new BuildPathPage(this));
|
|
|
|
setStartId(BuildPathPageId);
|
|
setWindowTitle(tr("Autotools Wizard"));
|
|
}
|
|
|
|
AutotoolsManager *AutotoolsOpenProjectWizard::autotoolsManager() const
|
|
{
|
|
return m_manager;
|
|
}
|
|
|
|
QString AutotoolsOpenProjectWizard::buildDirectory() const
|
|
{
|
|
return m_buildDirectory;
|
|
}
|
|
|
|
QString AutotoolsOpenProjectWizard::sourceDirectory() const
|
|
{
|
|
return m_sourceDirectory;
|
|
}
|
|
|
|
void AutotoolsOpenProjectWizard::setBuildDirectory(const QString &directory)
|
|
{
|
|
m_buildDirectory = directory;
|
|
}
|
|
|
|
/////////////////////////
|
|
// BuildPathPage class
|
|
/////////////////////////
|
|
BuildPathPage::BuildPathPage(AutotoolsOpenProjectWizard *wizard)
|
|
: QWizardPage(wizard), m_wizard(wizard)
|
|
{
|
|
QFormLayout *fl = new QFormLayout;
|
|
this->setLayout(fl);
|
|
|
|
QLabel *label = new QLabel(this);
|
|
label->setWordWrap(true);
|
|
label->setText(tr("Please enter the directory in which you want to build your project. "
|
|
"Qt Creator recommends to not use the source directory for building. "
|
|
"This ensures that the source directory remains clean and enables multiple builds "
|
|
"with different settings."));
|
|
fl->addWidget(label);
|
|
m_pc = new Utils::PathChooser(this);
|
|
m_pc->setBaseDirectory(m_wizard->sourceDirectory());
|
|
m_pc->setPath(m_wizard->buildDirectory());
|
|
connect(m_pc, SIGNAL(changed(QString)), this, SLOT(buildDirectoryChanged()));
|
|
fl->addRow(tr("Build directory:"), m_pc);
|
|
setTitle(tr("Build Location"));
|
|
}
|
|
|
|
void BuildPathPage::buildDirectoryChanged()
|
|
{
|
|
m_wizard->setBuildDirectory(m_pc->path());
|
|
}
|