2012-07-03 17:26:36 +00:00
|
|
|
TEMPLATE = app
|
|
|
|
|
|
|
|
CONFIG += qt warn_on console
|
2012-07-10 18:53:52 +00:00
|
|
|
isEmpty(QMAKE_INFO_PLIST): CONFIG -= app_bundle
|
2012-07-03 17:26:36 +00:00
|
|
|
|
|
|
|
build_all:!build_pass {
|
|
|
|
CONFIG -= build_all
|
|
|
|
CONFIG += release
|
|
|
|
}
|
|
|
|
|
|
|
|
target.path = $$[QT_INSTALL_BINS]
|
|
|
|
INSTALLS += target
|
|
|
|
|
|
|
|
# If we are doing a prefix build, create a "module" pri which enables
|
|
|
|
# qtPrepareTool() to work with the non-installed build.
|
|
|
|
!build_pass:!exists($$[QT_INSTALL_PREFIX]/.qmake.cache) {
|
|
|
|
|
|
|
|
isEmpty(MODULE):MODULE = $$TARGET
|
|
|
|
|
|
|
|
MODULE_DEPENDS = $$replace(QT, -private$, )
|
|
|
|
|
|
|
|
# Find the module's source root dir.
|
|
|
|
MODULE_PROFILE_DIR = $$_PRO_FILE_PWD_
|
|
|
|
for(ever) {
|
|
|
|
exists($$MODULE_PROFILE_DIR/sync.profile):break()
|
|
|
|
nmpri = $$dirname(MODULE_PROFILE_DIR)
|
|
|
|
equals(nmpri, $$MODULE_PROFILE_DIR): \
|
|
|
|
error("No sync.profile found. This does not look like a Qt module source tree.")
|
|
|
|
MODULE_PROFILE_DIR = $$nmpri
|
|
|
|
unset(nmpri)
|
|
|
|
}
|
|
|
|
|
|
|
|
isEmpty(MODULE_BASE_DIR): MODULE_BASE_DIR = $$MODULE_PROFILE_DIR
|
|
|
|
MODULE_BASE_OUTDIR = $$shadowed($$MODULE_BASE_DIR)
|
|
|
|
isEmpty(MODULE_QMAKE_OUTDIR): MODULE_QMAKE_OUTDIR = $$MODULE_BASE_OUTDIR
|
|
|
|
|
2012-07-10 18:53:52 +00:00
|
|
|
load(resolve_target)
|
2012-08-08 09:33:26 +00:00
|
|
|
cmd = $$shell_path($$QMAKE_RESOLVED_TARGET)
|
|
|
|
deps = $$resolve_depends(QT, "QT.")
|
|
|
|
!isEmpty(deps) {
|
2012-08-13 15:01:38 +00:00
|
|
|
plugin_paths =
|
2012-08-08 09:33:26 +00:00
|
|
|
for(dep, deps) {
|
|
|
|
deppath += $$shell_path($$eval(QT.$${dep}.libs))
|
2012-08-08 19:38:35 +00:00
|
|
|
for(rpath, QT.$${dep}.rpath_link): \
|
|
|
|
deppath += $$shell_path($$rpath)
|
2012-08-13 15:01:38 +00:00
|
|
|
plugin_paths += $$eval(QT.$${dep}.plugin_path) $$eval(QT.$${dep}.plugins)
|
2012-08-08 09:33:26 +00:00
|
|
|
}
|
|
|
|
deppath = $$unique(deppath)
|
2012-08-13 15:01:38 +00:00
|
|
|
plugin_paths = $$unique(plugin_paths)
|
|
|
|
pluginpath =
|
|
|
|
for(ppath, plugin_paths): \
|
|
|
|
exists($$ppath): \
|
|
|
|
pluginpath += $$shell_path($$ppath)
|
2012-08-08 09:33:26 +00:00
|
|
|
equals(QMAKE_DIR_SEP, /) {
|
|
|
|
equals(QMAKE_HOST.os, Windows): \
|
|
|
|
var = PATH
|
2012-08-11 20:28:25 +00:00
|
|
|
else:contains(QMAKE_HOST.os, Linux|FreeBSD): \
|
2012-08-08 09:33:26 +00:00
|
|
|
var = LD_LIBRARY_PATH
|
|
|
|
else:equals(QMAKE_HOST.os, Darwin): \
|
|
|
|
var = DYLD_LIBRARY_PATH
|
|
|
|
else: \
|
|
|
|
error("Operating system not supported.")
|
2012-08-13 15:01:38 +00:00
|
|
|
!isEmpty(pluginpath): pluginpath = "QT_PLUGIN_PATH=$$join(pluginpath, :) "
|
|
|
|
cmd = "$$var=$$join(deppath, :)${$$var:+:\$$$var} $$pluginpath$$cmd"
|
2012-08-08 09:33:26 +00:00
|
|
|
} else {
|
2012-08-13 15:01:38 +00:00
|
|
|
!isEmpty(pluginpath): pluginpath = "(set QT_PLUGIN_PATH=$$join(pluginpath, ;)) & "
|
2012-08-08 09:33:26 +00:00
|
|
|
# Escape closing parens when expanding %PATH%, otherwise cmd confuses itself.
|
2012-08-13 15:01:38 +00:00
|
|
|
cmd = "(set PATH=$$join(deppath, ;);%PATH:)=^)%) & $$pluginpath$$cmd"
|
2012-08-08 09:33:26 +00:00
|
|
|
}
|
|
|
|
}
|
2012-07-10 18:53:52 +00:00
|
|
|
|
2012-07-03 17:26:36 +00:00
|
|
|
TOOL_PRI = $$MODULE_QMAKE_OUTDIR/mkspecs/modules/qt_$${MODULE}.pri
|
|
|
|
|
2012-08-08 09:33:26 +00:00
|
|
|
TOOL_PRI_CONT = "QT_TOOL.$${MODULE}.command = $$val_escape(cmd)"
|
2012-07-03 17:26:36 +00:00
|
|
|
write_file($$TOOL_PRI, TOOL_PRI_CONT)|error("Aborting.")
|
|
|
|
|
|
|
|
# Then, inject the new tool into the current cache state
|
|
|
|
!contains(QMAKE_INTERNAL_INCLUDED_FILES, $$TOOL_PRI) { # before the actual include()!
|
|
|
|
added = $$TOOL_PRI
|
|
|
|
cache(QMAKE_INTERNAL_INCLUDED_FILES, add transient, added)
|
|
|
|
unset(added)
|
|
|
|
}
|
|
|
|
include($$TOOL_PRI)
|
|
|
|
for(var, $$list(binary depends)): \
|
|
|
|
cache(QT_TOOL.$${MODULE}.$$var, transient)
|
|
|
|
|
|
|
|
}
|