f9f395c28b
Updated version of LGPL and FDL licenseheaders. Apply release phase licenseheaders for all source files. Reviewed-by: Trust Me
524 lines
21 KiB
C++
524 lines
21 KiB
C++
/****************************************************************************
|
|
**
|
|
** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
|
|
** All rights reserved.
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
|
**
|
|
** This file is part of the qmake application of the Qt Toolkit.
|
|
**
|
|
** $QT_BEGIN_LICENSE:LGPL$
|
|
** 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.
|
|
**
|
|
** GNU General Public License Usage
|
|
** Alternatively, this file may be used under the terms of the GNU General
|
|
** Public License version 3.0 as published by the Free Software Foundation
|
|
** and appearing in the file LICENSE.GPL included in the packaging of this
|
|
** file. Please review the following information to ensure the GNU General
|
|
** Public License version 3.0 requirements will be met:
|
|
** http://www.gnu.org/copyleft/gpl.html.
|
|
**
|
|
** 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.
|
|
**
|
|
**
|
|
**
|
|
**
|
|
**
|
|
** $QT_END_LICENSE$
|
|
**
|
|
****************************************************************************/
|
|
|
|
#include "symmake_abld.h"
|
|
#include "initprojectdeploy_symbian.h"
|
|
|
|
#include <qstring.h>
|
|
#include <qstringlist.h>
|
|
#include <qdir.h>
|
|
#include <qdatetime.h>
|
|
#include <qdebug.h>
|
|
|
|
// Included from tools/shared
|
|
#include <symbian/epocroot_p.h>
|
|
|
|
#define DO_NOTHING_TARGET "do_nothing"
|
|
#define CREATE_TEMPS_TARGET "create_temps"
|
|
#define EXTENSION_CLEAN "extension_clean"
|
|
#define PRE_TARGETDEPS_TARGET "pre_targetdeps"
|
|
#define COMPILER_CLEAN_TARGET "compiler_clean"
|
|
#define FINALIZE_TARGET "finalize"
|
|
#define GENERATED_SOURCES_TARGET "generated_sources"
|
|
#define ALL_SOURCE_DEPS_TARGET "all_source_deps"
|
|
#define DEPLOYMENT_TARGET "deployment"
|
|
#define DEPLOYMENT_CLEAN_TARGET "deployment_clean"
|
|
#define WINSCW_DEPLOYMENT_TARGET "winscw_deployment"
|
|
#define WINSCW_DEPLOYMENT_CLEAN_TARGET "winscw_deployment_clean"
|
|
#define STORE_BUILD_TARGET "store_build"
|
|
|
|
SymbianAbldMakefileGenerator::SymbianAbldMakefileGenerator() : SymbianMakefileGenerator() { }
|
|
SymbianAbldMakefileGenerator::~SymbianAbldMakefileGenerator() { }
|
|
|
|
void SymbianAbldMakefileGenerator::writeMkFile(const QString& wrapperFileName, bool deploymentOnly)
|
|
{
|
|
QFile ft(gnuMakefileName);
|
|
if (ft.open(QIODevice::WriteOnly)) {
|
|
generatedFiles << ft.fileName();
|
|
QTextStream t(&ft);
|
|
|
|
t << "# ==============================================================================" << endl;
|
|
t << "# Generated by qmake (" << qmake_version() << ") (Qt " << QT_VERSION_STR << ") on: ";
|
|
t << QDateTime::currentDateTime().toString() << endl;
|
|
t << "# This file is generated by qmake and should not be modified by the" << endl;
|
|
t << "# user." << endl;
|
|
t << "# Name : " << gnuMakefileName << endl;
|
|
t << "# Part of : " << project->values("TARGET").join(" ") << endl;
|
|
t << "# Description : This file is used to call necessary targets on wrapper makefile" << endl;
|
|
t << "# during normal Symbian build process." << endl;
|
|
t << "# Version : " << endl;
|
|
t << "#" << endl;
|
|
t << "# ==============================================================================" << "\n" << endl;
|
|
|
|
t << endl << endl;
|
|
|
|
t << "MAKE = make" << endl;
|
|
t << endl;
|
|
|
|
t << "VISUAL_CFG = RELEASE" << endl;
|
|
t << "ifeq \"$(CFG)\" \"UDEB\"" << endl;
|
|
t << "VISUAL_CFG = DEBUG" << endl;
|
|
t << "endif" << endl;
|
|
t << endl;
|
|
|
|
t << DO_NOTHING_TARGET " :" << endl;
|
|
t << "\t" << "@rem " DO_NOTHING_TARGET << endl << endl;
|
|
|
|
QString buildDeps;
|
|
QString cleanDeps;
|
|
QString finalDeps;
|
|
QString cleanDepsWinscw;
|
|
QString finalDepsWinscw;
|
|
QStringList wrapperTargets;
|
|
if (deploymentOnly) {
|
|
buildDeps.append(STORE_BUILD_TARGET);
|
|
cleanDeps.append(DEPLOYMENT_CLEAN_TARGET);
|
|
cleanDepsWinscw.append(WINSCW_DEPLOYMENT_CLEAN_TARGET " " DEPLOYMENT_CLEAN_TARGET);
|
|
finalDeps.append(DEPLOYMENT_TARGET);
|
|
finalDepsWinscw.append(WINSCW_DEPLOYMENT_TARGET " " DEPLOYMENT_TARGET);
|
|
wrapperTargets << WINSCW_DEPLOYMENT_TARGET
|
|
<< WINSCW_DEPLOYMENT_CLEAN_TARGET
|
|
<< DEPLOYMENT_TARGET
|
|
<< DEPLOYMENT_CLEAN_TARGET
|
|
<< STORE_BUILD_TARGET;
|
|
} else {
|
|
buildDeps.append(CREATE_TEMPS_TARGET " " PRE_TARGETDEPS_TARGET " " STORE_BUILD_TARGET);
|
|
cleanDeps.append(EXTENSION_CLEAN " " DEPLOYMENT_CLEAN_TARGET);
|
|
cleanDepsWinscw.append(EXTENSION_CLEAN " " WINSCW_DEPLOYMENT_CLEAN_TARGET " " DEPLOYMENT_CLEAN_TARGET);
|
|
finalDeps.append(FINALIZE_TARGET " " DEPLOYMENT_TARGET);
|
|
finalDepsWinscw.append(FINALIZE_TARGET " " WINSCW_DEPLOYMENT_TARGET " " DEPLOYMENT_TARGET);
|
|
wrapperTargets << PRE_TARGETDEPS_TARGET
|
|
<< CREATE_TEMPS_TARGET
|
|
<< EXTENSION_CLEAN
|
|
<< FINALIZE_TARGET
|
|
<< WINSCW_DEPLOYMENT_CLEAN_TARGET
|
|
<< WINSCW_DEPLOYMENT_TARGET
|
|
<< DEPLOYMENT_CLEAN_TARGET
|
|
<< DEPLOYMENT_TARGET
|
|
<< STORE_BUILD_TARGET;
|
|
}
|
|
|
|
t << "MAKMAKE: " << buildDeps << endl << endl;
|
|
t << "LIB: " << buildDeps << endl << endl;
|
|
t << "BLD: " << buildDeps << endl << endl;
|
|
t << "ifeq \"$(PLATFORM)\" \"WINSCW\"" << endl;
|
|
t << "CLEAN: " << cleanDepsWinscw << endl;
|
|
t << "else" << endl;
|
|
t << "CLEAN: " << cleanDeps << endl;
|
|
t << "endif" << endl << endl;
|
|
t << "CLEANLIB: " DO_NOTHING_TARGET << endl << endl;
|
|
t << "RESOURCE: " DO_NOTHING_TARGET << endl << endl;
|
|
t << "FREEZE: " DO_NOTHING_TARGET << endl << endl;
|
|
t << "SAVESPACE: " DO_NOTHING_TARGET << endl << endl;
|
|
t << "RELEASABLES: " DO_NOTHING_TARGET << endl << endl;
|
|
t << "ifeq \"$(PLATFORM)\" \"WINSCW\"" << endl;
|
|
t << "FINAL: " << finalDepsWinscw << endl;
|
|
t << "else" << endl;
|
|
t << "FINAL: " << finalDeps << endl;
|
|
t << "endif" << endl << endl;
|
|
|
|
QString makefile(Option::fixPathToTargetOS(fileInfo(wrapperFileName).canonicalFilePath()));
|
|
foreach(QString target, wrapperTargets) {
|
|
t << target << " : " << makefile << endl;
|
|
t << "\t-$(MAKE) -f \"" << makefile << "\" " << target << " QT_SIS_TARGET=$(VISUAL_CFG)-$(PLATFORM)" << endl << endl;
|
|
}
|
|
|
|
t << endl;
|
|
} // if(ft.open(QIODevice::WriteOnly))
|
|
}
|
|
|
|
void SymbianAbldMakefileGenerator::writeWrapperMakefile(QFile& wrapperFile, bool isPrimaryMakefile)
|
|
{
|
|
QStringList allPlatforms;
|
|
foreach(QString platform, project->values("SYMBIAN_PLATFORMS")) {
|
|
allPlatforms << platform.toLower();
|
|
}
|
|
|
|
QStringList debugPlatforms = allPlatforms;
|
|
QStringList releasePlatforms = allPlatforms;
|
|
releasePlatforms.removeAll("winscw"); // No release for emulator
|
|
|
|
QString testClause;
|
|
if (project->isActiveConfig(SYMBIAN_TEST_CONFIG))
|
|
testClause = QLatin1String(" test");
|
|
else
|
|
testClause = QLatin1String("");
|
|
|
|
QTextStream t(&wrapperFile);
|
|
|
|
MakefileGenerator::writeHeader(t);
|
|
|
|
t << "MAKEFILE = " << fileInfo(wrapperFile.fileName()).fileName() << endl;
|
|
t << "QMAKE = " << var("QMAKE_QMAKE") << endl;
|
|
t << "DEL_FILE = " << var("QMAKE_DEL_FILE") << endl;
|
|
t << "DEL_DIR = " << var("QMAKE_DEL_DIR") << endl;
|
|
t << "DEL_TREE = " << var("QMAKE_DEL_TREE") << endl;
|
|
t << "MOVE = " << var("QMAKE_MOVE") << endl;
|
|
t << "CHK_DIR_EXISTS = " << var("QMAKE_CHK_DIR_EXISTS") << endl;
|
|
t << "MKDIR = " << var("QMAKE_MKDIR") << endl;
|
|
#ifdef Q_OS_WIN32
|
|
t << "XCOPY = xcopy /d /f /h /r /y /i" << endl;
|
|
t << "ABLD = ABLD.BAT" << endl;
|
|
#elif defined(Q_OS_MAC)
|
|
t << "XCOPY = cp -R -v" << endl;
|
|
t << "ABLD = abld" << endl;
|
|
#else
|
|
t << "XCOPY = cp -R -u -v" << endl;
|
|
t << "ABLD = abld" << endl;
|
|
#endif
|
|
t << "DEBUG_PLATFORMS = " << debugPlatforms.join(" ") << endl;
|
|
t << "RELEASE_PLATFORMS = " << releasePlatforms.join(" ") << endl;
|
|
t << "MAKE = make" << endl;
|
|
t << endl;
|
|
t << "ifeq (WINS,$(findstring WINS, $(PLATFORM)))" << endl;
|
|
t << "ZDIR=$(EPOCROOT)" << QDir::toNativeSeparators("epoc32/release/$(PLATFORM)/$(CFG)/z") << endl;
|
|
t << "else" << endl;
|
|
t << "ZDIR=$(EPOCROOT)" << QDir::toNativeSeparators("epoc32/data/z") << endl;
|
|
t << "endif" << endl;
|
|
t << endl;
|
|
t << "DEFINES" << '\t' << " = "
|
|
<< varGlue("PRL_EXPORT_DEFINES","-D"," -D"," ")
|
|
<< varGlue("QMAKE_COMPILER_DEFINES", "-D", "-D", " ")
|
|
<< varGlue("DEFINES","-D"," -D","") << endl;
|
|
|
|
t << "INCPATH" << '\t' << " = ";
|
|
|
|
for (QMap<QString, QStringList>::iterator it = systeminclude.begin(); it != systeminclude.end(); ++it) {
|
|
QStringList values = it.value();
|
|
for (int i = 0; i < values.size(); ++i) {
|
|
t << " -I\"" << values.at(i) << "\"";
|
|
}
|
|
}
|
|
t << endl;
|
|
t << "first: default" << endl;
|
|
if (debugPlatforms.contains("winscw"))
|
|
t << "default: debug-winscw";
|
|
else if (debugPlatforms.contains("armv5"))
|
|
t << "default: debug-armv5";
|
|
else if (debugPlatforms.size())
|
|
t << "default: debug-" << debugPlatforms.first();
|
|
else
|
|
t << "default: all";
|
|
|
|
t << endl;
|
|
if (!isPrimaryMakefile) {
|
|
t << "all:" << endl;
|
|
} else {
|
|
t << "all: debug release" << endl;
|
|
t << endl;
|
|
|
|
QString qmakeCmd = "\t$(QMAKE) \"" + project->projectFile() + "\" " + buildArgs();
|
|
|
|
t << "qmake:" << endl;
|
|
t << qmakeCmd << endl;
|
|
t << endl;
|
|
|
|
t << BLD_INF_FILENAME ": " << project->projectFile() << endl;
|
|
t << qmakeCmd << endl;
|
|
t << endl;
|
|
|
|
t << "$(ABLD): " BLD_INF_FILENAME << endl;
|
|
t << "\tbldmake bldfiles" << endl;
|
|
t << endl;
|
|
|
|
QString locFileDep = generateLocFileTarget(t, qmakeCmd);
|
|
|
|
t << "debug: " << locFileDep << "$(ABLD)" << endl;
|
|
foreach(QString item, debugPlatforms) {
|
|
t << "\t$(ABLD)" << testClause << " build " << item << " udeb" << endl;
|
|
}
|
|
t << endl;
|
|
t << "release: " << locFileDep << "$(ABLD)" << endl;
|
|
foreach(QString item, releasePlatforms) {
|
|
t << "\t$(ABLD)" << testClause << " build " << item << " urel" << endl;
|
|
}
|
|
t << endl;
|
|
|
|
// For more specific builds, targets are in this form: build-platform, e.g. release-armv5
|
|
foreach(QString item, debugPlatforms) {
|
|
t << "debug-" << item << ": " << locFileDep << "$(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " build " << item << " udeb" << endl;
|
|
}
|
|
|
|
foreach(QString item, releasePlatforms) {
|
|
t << "release-" << item << ": " << locFileDep << "$(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " build " << item << " urel" << endl;
|
|
}
|
|
|
|
t << endl;
|
|
t << "export: $(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " export" << endl;
|
|
t << endl;
|
|
|
|
t << "cleanexport: $(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " cleanexport" << endl;
|
|
t << endl;
|
|
|
|
}
|
|
|
|
// pre_targetdeps target depends on:
|
|
// - all targets specified in PRE_TARGETDEPS
|
|
// - the GENERATED_SOURCES sources (so that they get generated)
|
|
// - all dependencies of sources targeted for compilation
|
|
// (mainly to ensure that any included UNUSED_SOURCES that need to be generated get generated)
|
|
//
|
|
// Unfortunately, Symbian build chain doesn't support linking generated objects to target,
|
|
// so supporting generating sources is the best we can do. This is enough for mocs.
|
|
|
|
if (targetType != TypeSubdirs) {
|
|
writeExtraTargets(t);
|
|
writeExtraCompilerTargets(t);
|
|
|
|
t << CREATE_TEMPS_TARGET ":" << endl;
|
|
// generate command lines like this ...
|
|
// -@ if NOT EXIST ".\somedir" mkdir ".\somedir"
|
|
QStringList dirsToClean;
|
|
QString dirExists = var("QMAKE_CHK_DIR_EXISTS");
|
|
QString mkdir = var("QMAKE_MKDIR");
|
|
for (QMap<QString, QStringList>::iterator it = systeminclude.begin(); it != systeminclude.end(); ++it) {
|
|
QStringList values = it.value();
|
|
for (int i = 0; i < values.size(); ++i) {
|
|
if (values.at(i).endsWith("/" QT_EXTRA_INCLUDE_DIR)) {
|
|
QString fixedValue(QDir::toNativeSeparators(values.at(i)));
|
|
dirsToClean << fixedValue;
|
|
t << "\t-@ " << dirExists << " \"" << fixedValue << "\" "
|
|
<< (isWindowsShell() ? "" : "|| ")
|
|
<< mkdir << " \"" << fixedValue << "\"" << endl;
|
|
}
|
|
}
|
|
}
|
|
t << endl;
|
|
|
|
// Note: EXTENSION_CLEAN will get called many times when doing reallyclean
|
|
// This is why the "2> NUL" gets appended to generated clean targets in makefile.cpp.
|
|
t << EXTENSION_CLEAN ": " COMPILER_CLEAN_TARGET << endl;
|
|
generateCleanCommands(t, dirsToClean, "$(DEL_TREE)", "", "", "");
|
|
generateCleanCommands(t, project->values("QMAKE_CLEAN"), "$(DEL_FILE)", "", "", "");
|
|
t << endl;
|
|
|
|
t << PRE_TARGETDEPS_TARGET ":"
|
|
<< MAKEFILE_DEPENDENCY_SEPARATOR GENERATED_SOURCES_TARGET
|
|
<< MAKEFILE_DEPENDENCY_SEPARATOR ALL_SOURCE_DEPS_TARGET;
|
|
if (project->values("PRE_TARGETDEPS").size())
|
|
t << MAKEFILE_DEPENDENCY_SEPARATOR << project->values("PRE_TARGETDEPS").join(MAKEFILE_DEPENDENCY_SEPARATOR);
|
|
t << endl << endl;
|
|
t << GENERATED_SOURCES_TARGET ":";
|
|
if (project->values("GENERATED_SOURCES").size())
|
|
t << MAKEFILE_DEPENDENCY_SEPARATOR << project->values("GENERATED_SOURCES").join(MAKEFILE_DEPENDENCY_SEPARATOR);
|
|
t << endl << endl;
|
|
t << ALL_SOURCE_DEPS_TARGET ":";
|
|
|
|
QStringList allDeps;
|
|
for (QMap<QString, QStringList>::iterator it = sources.begin(); it != sources.end(); ++it) {
|
|
QString currentSourcePath = it.key();
|
|
QStringList values = it.value();
|
|
for (int i = 0; i < values.size(); ++i) {
|
|
// we need additional check
|
|
QString sourceFile = currentSourcePath + "/" + values.at(i);
|
|
QStringList deps = findDependencies(QDir::toNativeSeparators(sourceFile));
|
|
appendIfnotExist(allDeps, deps);
|
|
}
|
|
}
|
|
|
|
foreach(QString item, allDeps) {
|
|
t << MAKEFILE_DEPENDENCY_SEPARATOR << item;
|
|
}
|
|
t << endl << endl;
|
|
|
|
// Post link operations
|
|
t << FINALIZE_TARGET ":" << endl;
|
|
if (!project->isEmpty("QMAKE_POST_LINK")) {
|
|
t << '\t' << var("QMAKE_POST_LINK");
|
|
t << endl;
|
|
}
|
|
t << endl;
|
|
} else {
|
|
QList<MakefileGenerator::SubTarget*> subtargets = findSubDirsSubTargets();
|
|
writeSubTargets(t, subtargets, SubTargetSkipDefaultVariables | SubTargetSkipDefaultTargets);
|
|
qDeleteAll(subtargets);
|
|
}
|
|
|
|
// Deploymend targets for both emulator and rom deployment
|
|
writeDeploymentTargets(t, false);
|
|
writeDeploymentTargets(t, true);
|
|
|
|
generateDistcleanTargets(t);
|
|
|
|
t << "clean: $(ABLD)" << endl;
|
|
t << "\t-$(ABLD)" << testClause << " reallyclean" << endl;
|
|
t << "\t-bldmake clean" << endl;
|
|
t << endl;
|
|
|
|
t << "clean-debug: $(ABLD)" << endl;
|
|
foreach(QString item, debugPlatforms) {
|
|
t << "\t$(ABLD)" << testClause << " reallyclean " << item << " udeb" << endl;
|
|
}
|
|
t << endl;
|
|
t << "clean-release: $(ABLD)" << endl;
|
|
foreach(QString item, releasePlatforms) {
|
|
t << "\t$(ABLD)" << testClause << " reallyclean " << item << " urel" << endl;
|
|
}
|
|
t << endl;
|
|
|
|
// For more specific builds, targets are in this form: clean-build-platform, e.g. clean-release-armv5
|
|
foreach(QString item, debugPlatforms) {
|
|
t << "clean-debug-" << item << ": $(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " reallyclean " << item << " udeb" << endl;
|
|
}
|
|
foreach(QString item, releasePlatforms) {
|
|
t << "clean-release-" << item << ": $(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " reallyclean " << item << " urel" << endl;
|
|
}
|
|
t << endl;
|
|
|
|
t << "freeze: $(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " freeze" << endl;
|
|
t << endl;
|
|
|
|
// Abld toolchain doesn't differentiate between freezing release or debug
|
|
t << "freeze-debug: freeze" << endl << endl;
|
|
t << "freeze-release: freeze" << endl << endl;
|
|
|
|
// For more specific builds, targets are in this form: freeze-build-platform, e.g. freeze-release-armv5,
|
|
// though note that debug and release targets of each platform are identical in symbian-abld.
|
|
foreach(QString item, debugPlatforms) {
|
|
t << "freeze-debug-" << item << ": $(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " freeze " << item << endl;
|
|
}
|
|
foreach(QString item, releasePlatforms) {
|
|
t << "freeze-release-" << item << ": $(ABLD)" << endl;
|
|
t << "\t$(ABLD)" << testClause << " freeze " << item << endl;
|
|
}
|
|
|
|
t << endl;
|
|
}
|
|
|
|
void SymbianAbldMakefileGenerator::writeBldInfExtensionRulesPart(QTextStream& t, const QString &iconTargetFile)
|
|
{
|
|
// We don't use extensions for anything in abld
|
|
Q_UNUSED(t);
|
|
Q_UNUSED(iconTargetFile);
|
|
}
|
|
|
|
bool SymbianAbldMakefileGenerator::writeDeploymentTargets(QTextStream &t, bool isRom)
|
|
{
|
|
if (isRom)
|
|
t << DEPLOYMENT_TARGET ":" << endl;
|
|
else
|
|
t << WINSCW_DEPLOYMENT_TARGET ":" << endl;
|
|
|
|
QString remoteTestPath = qt_epocRoot()
|
|
+ QDir::toNativeSeparators(QLatin1String(isRom ? "epoc32/data/z/private/"
|
|
: "epoc32/winscw/c/private/"))
|
|
+ privateDirUid;
|
|
DeploymentList depList;
|
|
|
|
initProjectDeploySymbian(project, depList, remoteTestPath, false, true,
|
|
QLatin1String(isRom ? ROM_DEPLOYMENT_PLATFORM : EMULATOR_DEPLOYMENT_PLATFORM),
|
|
QString(), generatedDirs, generatedFiles);
|
|
|
|
if (depList.size())
|
|
t << "\t-echo Deploying changed files..." << endl;
|
|
|
|
for (int i = 0; i < depList.size(); ++i) {
|
|
#ifdef Q_OS_WIN32
|
|
// Xcopy prompts for selecting file or directory if target doesn't exist,
|
|
// and doesn't provide switch to force file selection. It does provide dir forcing, though,
|
|
// so strip the last part of the destination.
|
|
t << "\t-$(XCOPY) \"" << depList.at(i).from << "\" \""
|
|
<< depList.at(i).to.left(depList.at(i).to.lastIndexOf("\\") + 1) << "\"" << endl;
|
|
#else
|
|
QString dirExists = var("QMAKE_CHK_DIR_EXISTS");
|
|
QString mkdir = var("QMAKE_MKDIR");
|
|
QString dir = QFileInfo(depList.at(i).to).dir().path();
|
|
t << "\t-@ " << dirExists << " \"" << dir << "\" || "
|
|
<< mkdir << " \"" << dir << "\"" << endl;
|
|
t << "\t-$(XCOPY) \"" << QDir::toNativeSeparators(depList.at(i).from) << "\" \""
|
|
<< QDir::toNativeSeparators(depList.at(i).to) << "\"" << endl;
|
|
#endif
|
|
}
|
|
|
|
t << endl;
|
|
|
|
if (isRom)
|
|
t << DEPLOYMENT_CLEAN_TARGET ":" << endl;
|
|
else
|
|
t << WINSCW_DEPLOYMENT_CLEAN_TARGET ":" << endl;
|
|
|
|
QStringList cleanList;
|
|
for (int i = 0; i < depList.size(); ++i) {
|
|
cleanList.append(QDir::toNativeSeparators(depList.at(i).to));
|
|
}
|
|
generateCleanCommands(t, cleanList, "$(DEL_FILE)", "", "", "");
|
|
|
|
// Note: If deployment creates any directories, they will not get deleted after cleanup.
|
|
// To do this in robust fashion could be quite complex.
|
|
|
|
t << endl;
|
|
|
|
return true;
|
|
}
|
|
|
|
void SymbianAbldMakefileGenerator::writeBldInfMkFilePart(QTextStream& t, bool addDeploymentExtension)
|
|
{
|
|
// Normally emulator deployment gets done via regular makefile, but since subdirs
|
|
// do not get that, special deployment only makefile is generated for them if needed.
|
|
if (targetType != TypeSubdirs || addDeploymentExtension) {
|
|
gnuMakefileName = QLatin1String("Makefile_") + fileInfo(mmpFileName).completeBaseName()
|
|
+ QLatin1String(".mk");
|
|
t << "gnumakefile " << gnuMakefileName << endl;
|
|
}
|
|
}
|
|
|
|
void SymbianAbldMakefileGenerator::appendAbldTempDirs(QStringList& sysincspaths, QString includepath)
|
|
{
|
|
// As a workaround for Symbian toolchain insistence to treat include
|
|
// statements as relative to source file rather than the file they appear in,
|
|
// we generate extra temporary include directories to make
|
|
// relative include paths used in various headers to work properly.
|
|
// Note that this is not a fix-all solution; it's just a stop-gap measure
|
|
// to make Qt itself build until toolchain can support relative includes in
|
|
// a way that Qt expects.
|
|
QString epocPath("epoc32");
|
|
if (!includepath.contains(epocPath)) // No temp dirs for epoc includes
|
|
appendIfnotExist(sysincspaths, includepath + QString("/" QT_EXTRA_INCLUDE_DIR));
|
|
}
|