diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | ce4a32fe52ef09d8f5ff1dd22c001110902b60a2 (patch) | |
tree | 5ac38a06f3dde268dc7927dc155896926aaf7012 /kdecore/tests/kmacroexpandertest.cpp | |
download | tdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.tar.gz tdelibs-ce4a32fe52ef09d8f5ff1dd22c001110902b60a2.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdelibs@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kdecore/tests/kmacroexpandertest.cpp')
-rw-r--r-- | kdecore/tests/kmacroexpandertest.cpp | 137 |
1 files changed, 137 insertions, 0 deletions
diff --git a/kdecore/tests/kmacroexpandertest.cpp b/kdecore/tests/kmacroexpandertest.cpp new file mode 100644 index 000000000..6c92ba935 --- /dev/null +++ b/kdecore/tests/kmacroexpandertest.cpp @@ -0,0 +1,137 @@ +#include <kmacroexpander.h> + +#include <kapplication.h> +#include <kcmdlineargs.h> +#include <kdebug.h> + +#include <stdlib.h> + +bool check(QString txt, QString s, QString a, QString b) +{ + if (a.isEmpty()) + a = QString::null; + if (b.isEmpty()) + b = QString::null; + if (a == b) + kdDebug() << txt << " (" << s << ") : '" << a << "' - ok" << endl; + else { + kdDebug() << txt << " (" << s << ") : got '" << a << "' but expected '" << b << "' - KO!" << endl; + exit(1); + } + return true; +} + +class MyCExpander : public KCharMacroExpander { +public: + MyCExpander() : KCharMacroExpander() {} +protected: + bool expandMacro(QChar chr, QStringList &ret) + { + if (chr == 'm') { + ret = QString("expanded"); + return true; + } + return false; + } +}; + +class MyWExpander : public KWordMacroExpander { +public: + MyWExpander() : KWordMacroExpander() {} +protected: + bool expandMacro(const QString &str, QStringList &ret) + { + if (str == "macro") { + ret = QString("expanded"); + return true; + } + return false; + } +}; + +int main(int argc, char *argv[]) +{ + KCmdLineArgs::init(argc, argv, ":", "", "", ""); + KApplication app(false,false); + QString s, s2; + + QMap<QChar,QStringList> map1; + map1.insert('n', "Restaurant \"Chew It\""); + QStringList li; + li << "element1" << "'element2'"; + map1.insert('l', li); + + s = "text %l %n text"; + check( "KMacroExpander::expandMacros", s, KMacroExpander::expandMacros(s, map1), "text element1 'element2' Restaurant \"Chew It\" text"); + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map1), "text 'element1' ''\\''element2'\\''' 'Restaurant \"Chew It\"' text"); + s = "text \"%l %n\" text"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map1), "text \"element1 'element2' Restaurant \\\"Chew It\\\"\" text"); + + QMap<QChar,QString> map; + map.insert('a', "%n"); + map.insert('f', "filename.txt"); + map.insert('u', "http://www.kde.org/index.html"); + map.insert('n', "Restaurant \"Chew It\""); + + s = "Title: %a - %f - %u - %n - %%"; + check( "KMacroExpander::expandMacros", s, KMacroExpander::expandMacros(s, map), "Title: %n - filename.txt - http://www.kde.org/index.html - Restaurant \"Chew It\" - %"); + + s = "kedit --caption %n %f"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map), "kedit --caption 'Restaurant \"Chew It\"' 'filename.txt'"); + + map.replace('n', "Restaurant 'Chew It'"); + s = "kedit --caption %n %f"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map), "kedit --caption 'Restaurant '\\''Chew It'\\''' 'filename.txt'"); + + s = "kedit --caption \"%n\" %f"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map), "kedit --caption \"Restaurant 'Chew It'\" 'filename.txt'"); + + map.replace('n', "Restaurant \"Chew It\""); + s = "kedit --caption \"%n\" %f"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map), "kedit --caption \"Restaurant \\\"Chew It\\\"\" 'filename.txt'"); + + map.replace('n', "Restaurant $HOME"); + s = "kedit --caption \"%n\" %f"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map), "kedit --caption \"Restaurant \\$HOME\" 'filename.txt'"); + + map.replace('n', "Restaurant `echo hello`"); + s = "kedit --caption \"%n\" %f"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map), "kedit --caption \"Restaurant \\`echo hello\\`\" 'filename.txt'"); + + map.replace('n', "Restaurant `echo hello`"); + s = "kedit --caption \"`echo %n`\" %f"; + check( "KMacroExpander::expandMacrosShellQuote", s, KMacroExpander::expandMacrosShellQuote(s, map), "kedit --caption \"$( echo 'Restaurant `echo hello`')\" 'filename.txt'"); + + QMap<QString,QString> smap; + smap.insert("foo", "%n"); + smap.insert("file", "filename.txt"); + smap.insert("url", "http://www.kde.org/index.html"); + smap.insert("name", "Restaurant \"Chew It\""); + + s = "Title: %foo - %file - %url - %name - %"; + check( "KMacroExpander::expandMacros", s, KMacroExpander::expandMacros(s, smap), "Title: %n - filename.txt - http://www.kde.org/index.html - Restaurant \"Chew It\" - %"); + + s = "Title: %{foo} - %{file} - %{url} - %{name} - %"; + check( "KMacroExpander::expandMacros", s, KMacroExpander::expandMacros(s, smap), "Title: %n - filename.txt - http://www.kde.org/index.html - Restaurant \"Chew It\" - %"); + + s = "Title: %foo-%file-%url-%name-%"; + check( "KMacroExpander::expandMacros", s, KMacroExpander::expandMacros(s, smap), "Title: %n-filename.txt-http://www.kde.org/index.html-Restaurant \"Chew It\"-%"); + + s = "Title: %{file} %{url"; + check( "KMacroExpander::expandMacros", s, KMacroExpander::expandMacros(s, smap), "Title: filename.txt %{url"); + + MyCExpander mx1; + s = "subst %m but not %n equ %%"; + s2 = s; + mx1.expandMacros(s2); + check( "MyCExpander::expandMacros", s, s2, "subst expanded but not %n equ %"); + + MyWExpander mx2; + s = "subst %macro but not %not equ %%"; + s2 = s; + mx2.expandMacros(s2); + check( "MyWExpander::expandMacros", s, s2, "subst expanded but not %not equ %"); + + kdDebug() << endl << "Test OK!" << endl; +} + |