forked from qt-creator/qt-creator
add $$system_path() & $$shell_path() functions
follow suit with qmake ... Change-Id: I41ceb93b234eafd5202c618a7af36e35278ad79f Reviewed-by: Daniel Teske <daniel.teske@nokia.com> Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@nokia.com>
This commit is contained in:
@@ -77,7 +77,8 @@ enum ExpandFunc {
|
|||||||
E_FIND, E_SYSTEM, E_UNIQUE, E_REVERSE, E_QUOTE, E_ESCAPE_EXPAND,
|
E_FIND, E_SYSTEM, E_UNIQUE, E_REVERSE, E_QUOTE, E_ESCAPE_EXPAND,
|
||||||
E_UPPER, E_LOWER, E_FILES, E_PROMPT, E_RE_ESCAPE, E_VAL_ESCAPE,
|
E_UPPER, E_LOWER, E_FILES, E_PROMPT, E_RE_ESCAPE, E_VAL_ESCAPE,
|
||||||
E_REPLACE, E_SORT_DEPENDS, E_RESOLVE_DEPENDS, E_ENUMERATE_VARS,
|
E_REPLACE, E_SORT_DEPENDS, E_RESOLVE_DEPENDS, E_ENUMERATE_VARS,
|
||||||
E_SHADOWED, E_ABSOLUTE_PATH, E_RELATIVE_PATH, E_CLEAN_PATH
|
E_SHADOWED, E_ABSOLUTE_PATH, E_RELATIVE_PATH, E_CLEAN_PATH,
|
||||||
|
E_SYSTEM_PATH, E_SHELL_PATH
|
||||||
};
|
};
|
||||||
|
|
||||||
enum TestFunc {
|
enum TestFunc {
|
||||||
@@ -128,6 +129,8 @@ void QMakeEvaluator::initFunctionStatics()
|
|||||||
{ "absolute_path", E_ABSOLUTE_PATH },
|
{ "absolute_path", E_ABSOLUTE_PATH },
|
||||||
{ "relative_path", E_RELATIVE_PATH },
|
{ "relative_path", E_RELATIVE_PATH },
|
||||||
{ "clean_path", E_CLEAN_PATH },
|
{ "clean_path", E_CLEAN_PATH },
|
||||||
|
{ "system_path", E_SYSTEM_PATH },
|
||||||
|
{ "shell_path", E_SHELL_PATH },
|
||||||
};
|
};
|
||||||
for (unsigned i = 0; i < sizeof(expandInits)/sizeof(expandInits[0]); ++i)
|
for (unsigned i = 0; i < sizeof(expandInits)/sizeof(expandInits[0]); ++i)
|
||||||
statics.expands.insert(ProString(expandInits[i].name), expandInits[i].func);
|
statics.expands.insert(ProString(expandInits[i].name), expandInits[i].func);
|
||||||
@@ -862,6 +865,31 @@ ProStringList QMakeEvaluator::evaluateExpandFunction(
|
|||||||
ret << ProString(QDir::cleanPath(args.at(0).toQString(m_tmp1)),
|
ret << ProString(QDir::cleanPath(args.at(0).toQString(m_tmp1)),
|
||||||
NoHash).setSource(args.at(0));
|
NoHash).setSource(args.at(0));
|
||||||
break;
|
break;
|
||||||
|
case E_SYSTEM_PATH:
|
||||||
|
if (args.count() != 1) {
|
||||||
|
evalError(fL1S("system_path(path) requires one argument."));
|
||||||
|
} else {
|
||||||
|
QString rstr = args.at(0).toQString(m_tmp1);
|
||||||
|
#ifdef Q_OS_WIN
|
||||||
|
rstr.replace(QLatin1Char('/'), QLatin1Char('\\'));
|
||||||
|
#else
|
||||||
|
rstr.replace(QLatin1Char('\\'), QLatin1Char('/'));
|
||||||
|
#endif
|
||||||
|
ret << ProString(rstr, NoHash).setSource(args.at(0));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case E_SHELL_PATH:
|
||||||
|
if (args.count() != 1) {
|
||||||
|
evalError(fL1S("shell_path(path) requires one argument."));
|
||||||
|
} else {
|
||||||
|
QString rstr = args.at(0).toQString(m_tmp1);
|
||||||
|
if (m_option->dir_sep.at(0) != QLatin1Char('/'))
|
||||||
|
rstr.replace(QLatin1Char('/'), QLatin1Char('\\'));
|
||||||
|
else
|
||||||
|
rstr.replace(QLatin1Char('\\'), QLatin1Char('/'));
|
||||||
|
ret << ProString(rstr, NoHash).setSource(args.at(0));
|
||||||
|
}
|
||||||
|
break;
|
||||||
case E_INVALID:
|
case E_INVALID:
|
||||||
evalError(fL1S("'%1' is not a recognized replace function.")
|
evalError(fL1S("'%1' is not a recognized replace function.")
|
||||||
.arg(func.toQString(m_tmp1)));
|
.arg(func.toQString(m_tmp1)));
|
||||||
|
|||||||
Reference in New Issue
Block a user