diff options
author | Oswald Buddenhagen <oswald.buddenhagen@nokia.com> | 2012-07-25 19:21:38 +0200 |
---|---|---|
committer | Oswald Buddenhagen <oswald.buddenhagen@nokia.com> | 2012-08-01 16:43:04 +0200 |
commit | 6c9c086632eeb287ed3329f5568d6e81c8e7458d (patch) | |
tree | 65d37f0dfd465471a3a89e63dbb096b929713c37 /src | |
parent | 58a431fac98abdcadaa87627a989a4379a1d7879 (diff) | |
download | qt-creator-6c9c086632eeb287ed3329f5568d6e81c8e7458d.tar.gz |
add $$clean_path() function
follow suit with qmake ...
Change-Id: Ic80bab44704baf8a265b0ebead6f0ec024653f73
Reviewed-by: Daniel Teske <daniel.teske@nokia.com>
Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@nokia.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/shared/proparser/qmakebuiltins.cpp | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/shared/proparser/qmakebuiltins.cpp b/src/shared/proparser/qmakebuiltins.cpp index 79a2a9c6bb..acfaf78ada 100644 --- a/src/shared/proparser/qmakebuiltins.cpp +++ b/src/shared/proparser/qmakebuiltins.cpp @@ -77,7 +77,7 @@ enum ExpandFunc { 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_REPLACE, E_SORT_DEPENDS, E_RESOLVE_DEPENDS, E_ENUMERATE_VARS, - E_SHADOWED, E_ABSOLUTE_PATH, E_RELATIVE_PATH + E_SHADOWED, E_ABSOLUTE_PATH, E_RELATIVE_PATH, E_CLEAN_PATH }; enum TestFunc { @@ -127,6 +127,7 @@ void QMakeEvaluator::initFunctionStatics() { "shadowed", E_SHADOWED }, { "absolute_path", E_ABSOLUTE_PATH }, { "relative_path", E_RELATIVE_PATH }, + { "clean_path", E_CLEAN_PATH }, }; for (unsigned i = 0; i < sizeof(expandInits)/sizeof(expandInits[0]); ++i) statics.expands.insert(ProString(expandInits[i].name), expandInits[i].func); @@ -854,6 +855,13 @@ ProStringList QMakeEvaluator::evaluateExpandFunction( QDir(args.count() > 1 ? args.at(1).toQString(m_tmp2) : currentDirectory()) .relativeFilePath(args.at(0).toQString(m_tmp1))), NoHash).setSource(args.at(0)); break; + case E_CLEAN_PATH: + if (args.count() != 1) + evalError(fL1S("clean_path(path) requires one argument.")); + else + ret << ProString(QDir::cleanPath(args.at(0).toQString(m_tmp1)), + NoHash).setSource(args.at(0)); + break; case E_INVALID: evalError(fL1S("'%1' is not a recognized replace function.") .arg(func.toQString(m_tmp1))); |