2012-10-02 09:12:39 +02:00
|
|
|
/****************************************************************************
|
2011-02-18 11:48:13 +01:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2011-02-18 11:48:13 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** This file is part of Qt Creator.
|
2011-02-18 11:48:13 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
** 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
|
2016-01-15 14:57:40 +01:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2011-02-18 11:48:13 +01:00
|
|
|
**
|
2016-01-15 14:57:40 +01:00
|
|
|
** GNU General Public License Usage
|
|
|
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
|
|
|
** General Public License version 3 as published by the Free Software
|
|
|
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
|
|
|
** included in the packaging of this file. Please review the following
|
|
|
|
|
** information to ensure the GNU General Public License requirements will
|
|
|
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
2011-02-18 11:48:13 +01:00
|
|
|
**
|
2012-10-02 09:12:39 +02:00
|
|
|
****************************************************************************/
|
2011-02-18 11:48:13 +01:00
|
|
|
|
2010-01-19 09:33:06 +01:00
|
|
|
#include "qmlprojectitem.h"
|
|
|
|
|
#include "filefilteritems.h"
|
2011-01-24 12:29:48 +01:00
|
|
|
|
2012-02-15 10:42:41 +01:00
|
|
|
#include <QDir>
|
2010-01-19 09:33:06 +01:00
|
|
|
|
|
|
|
|
namespace QmlProjectManager {
|
|
|
|
|
|
2010-01-19 13:53:48 +01:00
|
|
|
// kind of initialization
|
2010-01-19 09:33:06 +01:00
|
|
|
void QmlProjectItem::setSourceDirectory(const QString &directoryPath)
|
|
|
|
|
{
|
2017-02-28 17:15:19 +01:00
|
|
|
if (m_sourceDirectory == directoryPath)
|
2010-01-19 09:33:06 +01:00
|
|
|
return;
|
|
|
|
|
|
2017-02-28 17:15:19 +01:00
|
|
|
m_sourceDirectory = directoryPath;
|
2010-01-19 09:33:06 +01:00
|
|
|
|
2017-02-28 17:15:19 +01:00
|
|
|
for (int i = 0; i < m_content.size(); ++i) {
|
|
|
|
|
QmlProjectContentItem *contentElement = m_content.at(i);
|
2010-01-19 09:33:06 +01:00
|
|
|
FileFilterBaseItem *fileFilter = qobject_cast<FileFilterBaseItem*>(contentElement);
|
2010-01-19 13:53:48 +01:00
|
|
|
if (fileFilter) {
|
2010-01-19 09:33:06 +01:00
|
|
|
fileFilter->setDefaultDirectory(directoryPath);
|
2016-07-01 12:19:37 +03:00
|
|
|
connect(fileFilter, &FileFilterBaseItem::filesChanged,
|
|
|
|
|
this, &QmlProjectItem::qmlFilesChanged);
|
2010-01-19 13:53:48 +01:00
|
|
|
}
|
2010-01-19 09:33:06 +01:00
|
|
|
}
|
2010-02-03 08:59:38 +01:00
|
|
|
}
|
|
|
|
|
|
2017-11-28 15:57:15 +01:00
|
|
|
void QmlProjectItem::setTargetDirectory(const QString &directoryPath)
|
|
|
|
|
{
|
|
|
|
|
m_targetDirectory = directoryPath;
|
|
|
|
|
}
|
|
|
|
|
|
2010-03-21 09:36:54 +01:00
|
|
|
void QmlProjectItem::setImportPaths(const QStringList &importPaths)
|
2010-02-03 08:59:38 +01:00
|
|
|
{
|
2017-02-28 17:15:19 +01:00
|
|
|
if (m_importPaths != importPaths)
|
|
|
|
|
m_importPaths = importPaths;
|
2010-02-03 08:59:38 +01:00
|
|
|
}
|
|
|
|
|
|
2010-01-19 16:56:03 +01:00
|
|
|
/* Returns list of absolute paths */
|
2010-01-28 17:12:07 +01:00
|
|
|
QStringList QmlProjectItem::files() const
|
2010-01-19 09:33:06 +01:00
|
|
|
{
|
2010-01-28 17:12:07 +01:00
|
|
|
QStringList files;
|
2010-01-19 09:33:06 +01:00
|
|
|
|
2017-02-28 17:15:19 +01:00
|
|
|
for (QmlProjectContentItem *contentElement : m_content) {
|
|
|
|
|
if (auto fileFilter = qobject_cast<FileFilterBaseItem *>(contentElement)) {
|
2010-01-28 17:12:07 +01:00
|
|
|
foreach (const QString &file, fileFilter->files()) {
|
|
|
|
|
if (!files.contains(file))
|
|
|
|
|
files << file;
|
2010-01-19 09:33:06 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2010-01-28 17:12:07 +01:00
|
|
|
return files;
|
2010-01-19 09:33:06 +01:00
|
|
|
}
|
|
|
|
|
|
2010-02-17 11:20:35 +01:00
|
|
|
/**
|
|
|
|
|
Check whether the project would include a file path
|
|
|
|
|
- regardless whether the file already exists or not.
|
|
|
|
|
|
|
|
|
|
@param filePath: absolute file path to check
|
|
|
|
|
*/
|
|
|
|
|
bool QmlProjectItem::matchesFile(const QString &filePath) const
|
|
|
|
|
{
|
2017-02-28 17:15:19 +01:00
|
|
|
for (QmlProjectContentItem *contentElement : m_content) {
|
|
|
|
|
if (auto fileFilter = qobject_cast<FileFilterBaseItem *>(contentElement)) {
|
2010-02-17 11:20:35 +01:00
|
|
|
if (fileFilter->matchesFile(filePath))
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-29 13:38:41 +01:00
|
|
|
QList<Utils::EnvironmentItem> QmlProjectItem::environment() const
|
|
|
|
|
{
|
|
|
|
|
return m_environment;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void QmlProjectItem::addToEnviroment(const QString &key, const QString &value)
|
|
|
|
|
{
|
|
|
|
|
m_environment.append(Utils::EnvironmentItem(key, value));
|
|
|
|
|
}
|
|
|
|
|
|
2010-01-19 09:33:06 +01:00
|
|
|
} // namespace QmlProjectManager
|