2012-09-05 16:29:19 +00:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
2015-01-28 08:44:43 +00:00
|
|
|
** Copyright (C) 2015 The Qt Company Ltd.
|
|
|
|
** Contact: http://www.qt.io/licensing/
|
2012-09-05 16:29:19 +00:00
|
|
|
**
|
|
|
|
** This file is part of the qmake application of the Qt Toolkit.
|
|
|
|
**
|
2014-08-21 13:51:22 +00:00
|
|
|
** $QT_BEGIN_LICENSE:LGPL21$
|
2012-09-19 12:28:29 +00: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
|
2015-01-28 08:44:43 +00:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
|
|
** and conditions see http://www.qt.io/terms-conditions. For further
|
|
|
|
** information use the contact form at http://www.qt.io/contact-us.
|
2012-09-19 12:28:29 +00:00
|
|
|
**
|
2012-09-05 16:29:19 +00:00
|
|
|
** GNU Lesser General Public License Usage
|
2012-09-19 12:28:29 +00:00
|
|
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
2014-08-21 13:51:22 +00:00
|
|
|
** General Public License version 2.1 or version 3 as published by the Free
|
|
|
|
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
|
|
|
|
** LICENSE.LGPLv3 included in the packaging of this file. Please review the
|
|
|
|
** following information to ensure the GNU Lesser General Public License
|
|
|
|
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
|
|
|
|
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
2012-09-19 12:28:29 +00:00
|
|
|
**
|
2015-01-28 08:44:43 +00:00
|
|
|
** As a special exception, The Qt Company gives you certain additional
|
|
|
|
** rights. These rights are described in The Qt Company LGPL Exception
|
2012-09-05 16:29:19 +00:00
|
|
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
|
|
**
|
|
|
|
** $QT_END_LICENSE$
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef QMAKEGLOBALS_H
|
|
|
|
#define QMAKEGLOBALS_H
|
|
|
|
|
|
|
|
#include "qmake_global.h"
|
|
|
|
#include "proitems.h"
|
|
|
|
|
|
|
|
#ifdef QT_BUILD_QMAKE
|
|
|
|
# include <property.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <qhash.h>
|
|
|
|
#include <qstringlist.h>
|
|
|
|
#ifndef QT_BOOTSTRAPPED
|
|
|
|
# include <qprocess.h>
|
|
|
|
#endif
|
|
|
|
#ifdef PROEVALUATOR_THREAD_SAFE
|
|
|
|
# include <qmutex.h>
|
|
|
|
# include <qwaitcondition.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
QT_BEGIN_NAMESPACE
|
|
|
|
|
|
|
|
class QMakeEvaluator;
|
|
|
|
|
|
|
|
class QMakeBaseKey
|
|
|
|
{
|
|
|
|
public:
|
support a cache that is really just a cache
unlike .qmake.cache & co., the presence of this file has no magic
effects on where mkspecs, modules and other things are searched.
as the obvious name "cache" is of course already taken, we call it
"stash".
the file is searched up to the super cache (if present), otherwise up to
the normal cache/conf (if present), otherwise up to the root.
if it's not found, it is created next to the super cache (if present),
otherwise next to the cache/conf (if present), otherwise in the current
output directory.
note that the cache really should be created and populated by the
top-level project if there are subprojects: otherwise, if there is an
"anchor" (super/cache/conf), subprojects would race for updating the
cache and make a mess. without an "anchor", each subproject would just
create its own cache, kind of defeating its purpose. this is no
different from the existing "cache", but it's worth mentioning that
removing the "anchoring" function does not remove the "nesting order"
constraint.
Task-number: QTBUG-31340
Change-Id: I786d40cef40d14582a0dd4a9407863001bec4c98
Reviewed-by: Joerg Bornemann <joerg.bornemann@digia.com>
2013-11-07 19:40:00 +00:00
|
|
|
QMakeBaseKey(const QString &_root, const QString &_stash, bool _hostBuild);
|
2012-09-05 16:29:19 +00:00
|
|
|
|
|
|
|
QString root;
|
support a cache that is really just a cache
unlike .qmake.cache & co., the presence of this file has no magic
effects on where mkspecs, modules and other things are searched.
as the obvious name "cache" is of course already taken, we call it
"stash".
the file is searched up to the super cache (if present), otherwise up to
the normal cache/conf (if present), otherwise up to the root.
if it's not found, it is created next to the super cache (if present),
otherwise next to the cache/conf (if present), otherwise in the current
output directory.
note that the cache really should be created and populated by the
top-level project if there are subprojects: otherwise, if there is an
"anchor" (super/cache/conf), subprojects would race for updating the
cache and make a mess. without an "anchor", each subproject would just
create its own cache, kind of defeating its purpose. this is no
different from the existing "cache", but it's worth mentioning that
removing the "anchoring" function does not remove the "nesting order"
constraint.
Task-number: QTBUG-31340
Change-Id: I786d40cef40d14582a0dd4a9407863001bec4c98
Reviewed-by: Joerg Bornemann <joerg.bornemann@digia.com>
2013-11-07 19:40:00 +00:00
|
|
|
QString stash;
|
2012-09-05 16:29:19 +00:00
|
|
|
bool hostBuild;
|
|
|
|
};
|
|
|
|
|
|
|
|
uint qHash(const QMakeBaseKey &key);
|
|
|
|
bool operator==(const QMakeBaseKey &one, const QMakeBaseKey &two);
|
|
|
|
|
|
|
|
class QMakeBaseEnv
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
QMakeBaseEnv();
|
|
|
|
~QMakeBaseEnv();
|
|
|
|
|
|
|
|
#ifdef PROEVALUATOR_THREAD_SAFE
|
|
|
|
QMutex mutex;
|
|
|
|
QWaitCondition cond;
|
|
|
|
bool inProgress;
|
|
|
|
// The coupling of this flag to thread safety exists because for other
|
|
|
|
// use cases failure is immediately fatal anyway.
|
|
|
|
bool isOk;
|
|
|
|
#endif
|
|
|
|
QMakeEvaluator *evaluator;
|
|
|
|
};
|
|
|
|
|
|
|
|
class QMAKE_EXPORT QMakeCmdLineParserState
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
QMakeCmdLineParserState(const QString &_pwd) : pwd(_pwd), after(false) {}
|
|
|
|
QString pwd;
|
|
|
|
QStringList precmds, preconfigs, postcmds, postconfigs;
|
|
|
|
bool after;
|
2013-01-30 17:37:11 +00:00
|
|
|
|
|
|
|
void flush() { after = false; }
|
2012-09-05 16:29:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class QMAKE_EXPORT QMakeGlobals
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
QMakeGlobals();
|
|
|
|
~QMakeGlobals();
|
|
|
|
|
|
|
|
bool do_cache;
|
|
|
|
QString dir_sep;
|
|
|
|
QString dirlist_sep;
|
|
|
|
QString cachefile;
|
|
|
|
#ifdef PROEVALUATOR_SETENV
|
|
|
|
QProcessEnvironment environment;
|
|
|
|
#endif
|
|
|
|
QString qmake_abslocation;
|
2013-10-23 12:02:59 +00:00
|
|
|
QStringList qmake_args;
|
2012-09-05 16:29:19 +00:00
|
|
|
|
2015-07-13 09:21:22 +00:00
|
|
|
QString qtconf;
|
2012-09-05 16:29:19 +00:00
|
|
|
QString qmakespec, xqmakespec;
|
|
|
|
QString user_template, user_template_prefix;
|
|
|
|
QString precmds, postcmds;
|
|
|
|
|
|
|
|
#ifdef PROEVALUATOR_DEBUG
|
|
|
|
int debugLevel;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
enum ArgumentReturn { ArgumentUnknown, ArgumentMalformed, ArgumentsOk };
|
|
|
|
ArgumentReturn addCommandLineArguments(QMakeCmdLineParserState &state,
|
|
|
|
QStringList &args, int *pos);
|
|
|
|
void commitCommandLineArguments(QMakeCmdLineParserState &state);
|
|
|
|
void setCommandLineArguments(const QString &pwd, const QStringList &args);
|
|
|
|
void useEnvironment();
|
|
|
|
void setDirectories(const QString &input_dir, const QString &output_dir);
|
|
|
|
#ifdef QT_BUILD_QMAKE
|
|
|
|
void setQMakeProperty(QMakeProperty *prop) { property = prop; }
|
|
|
|
ProString propertyValue(const ProKey &name) const { return property->value(name); }
|
|
|
|
#else
|
|
|
|
# ifdef PROEVALUATOR_INIT_PROPS
|
|
|
|
bool initProperties();
|
|
|
|
# else
|
|
|
|
void setProperties(const QHash<QString, QString> &props);
|
2015-05-15 18:58:50 +00:00
|
|
|
void setProperties(const QHash<ProKey, ProString> &props) { properties = props; }
|
2012-09-05 16:29:19 +00:00
|
|
|
# endif
|
|
|
|
ProString propertyValue(const ProKey &name) const { return properties.value(name); }
|
|
|
|
#endif
|
|
|
|
|
|
|
|
QString expandEnvVars(const QString &str) const;
|
|
|
|
QString shadowedPath(const QString &fileName) const;
|
2013-09-05 16:30:05 +00:00
|
|
|
QStringList splitPathList(const QString &value) const;
|
2012-09-05 16:29:19 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
QString getEnv(const QString &) const;
|
|
|
|
QStringList getPathListEnv(const QString &var) const;
|
|
|
|
|
|
|
|
QString cleanSpec(QMakeCmdLineParserState &state, const QString &spec);
|
|
|
|
|
|
|
|
QString source_root, build_root;
|
|
|
|
|
|
|
|
#ifdef QT_BUILD_QMAKE
|
|
|
|
QMakeProperty *property;
|
|
|
|
#else
|
|
|
|
QHash<ProKey, ProString> properties;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef PROEVALUATOR_THREAD_SAFE
|
|
|
|
QMutex mutex;
|
|
|
|
#endif
|
|
|
|
QHash<QMakeBaseKey, QMakeBaseEnv *> baseEnvs;
|
|
|
|
|
|
|
|
friend class QMakeEvaluator;
|
|
|
|
};
|
|
|
|
|
|
|
|
QT_END_NAMESPACE
|
|
|
|
|
|
|
|
#endif // QMAKEGLOBALS_H
|