forked from qt-creator/qt-creator
add $$system_quote() & $$shell_quote() functions
follow suit with qmake ... Change-Id: I3db37ba73cb709d8baf200600ae29241bc26bee5 Reviewed-by: Daniel Teske <daniel.teske@nokia.com> Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@nokia.com>
This commit is contained in:
@@ -78,7 +78,7 @@ enum ExpandFunc {
|
||||
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_SHADOWED, E_ABSOLUTE_PATH, E_RELATIVE_PATH, E_CLEAN_PATH,
|
||||
E_SYSTEM_PATH, E_SHELL_PATH
|
||||
E_SYSTEM_PATH, E_SHELL_PATH, E_SYSTEM_QUOTE, E_SHELL_QUOTE
|
||||
};
|
||||
|
||||
enum TestFunc {
|
||||
@@ -131,6 +131,8 @@ void QMakeEvaluator::initFunctionStatics()
|
||||
{ "clean_path", E_CLEAN_PATH },
|
||||
{ "system_path", E_SYSTEM_PATH },
|
||||
{ "shell_path", E_SHELL_PATH },
|
||||
{ "system_quote", E_SYSTEM_QUOTE },
|
||||
{ "shell_quote", E_SHELL_QUOTE },
|
||||
};
|
||||
for (unsigned i = 0; i < sizeof(expandInits)/sizeof(expandInits[0]); ++i)
|
||||
statics.expands.insert(ProString(expandInits[i].name), expandInits[i].func);
|
||||
@@ -890,6 +892,25 @@ ProStringList QMakeEvaluator::evaluateExpandFunction(
|
||||
ret << ProString(rstr, NoHash).setSource(args.at(0));
|
||||
}
|
||||
break;
|
||||
case E_SYSTEM_QUOTE:
|
||||
if (args.count() != 1)
|
||||
evalError(fL1S("system_quote(arg) requires one argument."));
|
||||
else
|
||||
ret << ProString(IoUtils::shellQuote(args.at(0).toQString(m_tmp1)),
|
||||
NoHash).setSource(args.at(0));
|
||||
break;
|
||||
case E_SHELL_QUOTE:
|
||||
if (args.count() != 1) {
|
||||
evalError(fL1S("shell_quote(arg) requires one argument."));
|
||||
} else {
|
||||
QString rstr = args.at(0).toQString(m_tmp1);
|
||||
if (m_option->dir_sep.at(0) != QLatin1Char('/'))
|
||||
rstr = IoUtils::shellQuoteWin(rstr);
|
||||
else
|
||||
rstr = IoUtils::shellQuoteUnix(rstr);
|
||||
ret << ProString(rstr, NoHash).setSource(args.at(0));
|
||||
}
|
||||
break;
|
||||
case E_INVALID:
|
||||
evalError(fL1S("'%1' is not a recognized replace function.")
|
||||
.arg(func.toQString(m_tmp1)));
|
||||
|
||||
Reference in New Issue
Block a user