summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorhjk <hjk121@nokiamail.com>2014-10-13 10:24:29 +0200
committerhjk <hjk121@nokiamail.com>2014-10-13 11:51:03 +0200
commitdf3d22ef1c68f39c7ca0688955f8a44350ebc657 (patch)
tree82a6850e0a76639b2205d0c961a1e9834b10ce41 /src
parentb3f3c96bcaeb092aefc237465bb1c805bc1b5fe7 (diff)
downloadqt-creator-df3d22ef1c68f39c7ca0688955f8a44350ebc657.tar.gz
Utils: Move MacroExpander to file pair of its own
Change-Id: I777accd58dafca39a0d3e50541af325277c49c6b Reviewed-by: Tobias Hunger <tobias.hunger@theqtcompany.com>
Diffstat (limited to 'src')
-rw-r--r--src/libs/utils/macroexpander.cpp43
-rw-r--r--src/libs/utils/macroexpander.h54
-rw-r--r--src/libs/utils/stringutils.h15
-rw-r--r--src/libs/utils/utils-lib.pri6
-rw-r--r--src/libs/utils/utils.qbs2
-rw-r--r--src/plugins/debugger/debuggerkitinformation.cpp1
-rw-r--r--src/plugins/qtsupport/baseqtversion.cpp2
7 files changed, 105 insertions, 18 deletions
diff --git a/src/libs/utils/macroexpander.cpp b/src/libs/utils/macroexpander.cpp
new file mode 100644
index 0000000000..2c257d0661
--- /dev/null
+++ b/src/libs/utils/macroexpander.cpp
@@ -0,0 +1,43 @@
+/****************************************************************************
+**
+** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
+** Contact: http://www.qt-project.org/legal
+**
+** This file is part of Qt Creator.
+**
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Digia. For licensing terms and
+** conditions see http://qt.digia.com/licensing. For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Digia gives you certain additional
+** rights. These rights are described in the Digia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+****************************************************************************/
+
+#include "macroexpander.h"
+
+namespace Utils {
+
+MacroExpander::MacroExpander(const MacroExpander::Resolver &resolver)
+ : m_resolver(resolver)
+{}
+
+bool MacroExpander::resolveMacro(const QString &name, QString *ret)
+{
+ return m_resolver(name, ret);
+}
+
+} // namespace Utils
diff --git a/src/libs/utils/macroexpander.h b/src/libs/utils/macroexpander.h
new file mode 100644
index 0000000000..20af9732da
--- /dev/null
+++ b/src/libs/utils/macroexpander.h
@@ -0,0 +1,54 @@
+/****************************************************************************
+**
+** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
+** Contact: http://www.qt-project.org/legal
+**
+** This file is part of Qt Creator.
+**
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Digia. For licensing terms and
+** conditions see http://qt.digia.com/licensing. For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Digia gives you certain additional
+** rights. These rights are described in the Digia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+****************************************************************************/
+
+#ifndef UTILS_MACROEXPANDER_H
+#define UTILS_MACROEXPANDER_H
+
+#include "stringutils.h"
+
+#include <functional>
+
+namespace Utils {
+
+class QTCREATOR_UTILS_EXPORT MacroExpander : public AbstractMacroExpander
+{
+public:
+ typedef std::function<bool(const QString &name, QString *ret)> Resolver;
+
+ explicit MacroExpander(const Resolver &resolver);
+
+ bool resolveMacro(const QString &name, QString *ret);
+
+private:
+ Resolver m_resolver;
+};
+
+} // namespace Utils
+
+#endif // UTILS_MACROEXPANDER_H
diff --git a/src/libs/utils/stringutils.h b/src/libs/utils/stringutils.h
index 958d56976c..97d47d64e4 100644
--- a/src/libs/utils/stringutils.h
+++ b/src/libs/utils/stringutils.h
@@ -32,8 +32,6 @@
#include "utils_global.h"
-#include <functional>
-
QT_BEGIN_NAMESPACE
class QStringList;
QT_END_NAMESPACE
@@ -77,19 +75,6 @@ private:
bool expandNestedMacros(const QString &str, int *pos, QString *ret);
};
-class QTCREATOR_UTILS_EXPORT MacroExpander : public AbstractMacroExpander
-{
-public:
- typedef std::function<bool(const QString &name, QString *ret)> Resolver;
-
- explicit MacroExpander(const Resolver &resolver) : m_resolver(resolver) {}
-
- bool resolveMacro(const QString &name, QString *ret) { return m_resolver(name, ret); }
-
-private:
- Resolver m_resolver;
-};
-
QTCREATOR_UTILS_EXPORT void expandMacros(QString *str, AbstractMacroExpander *mx);
QTCREATOR_UTILS_EXPORT QString expandMacros(const QString &str, AbstractMacroExpander *mx);
diff --git a/src/libs/utils/utils-lib.pri b/src/libs/utils/utils-lib.pri
index 4647b5f1cc..68c007a364 100644
--- a/src/libs/utils/utils-lib.pri
+++ b/src/libs/utils/utils-lib.pri
@@ -90,7 +90,8 @@ SOURCES += $$PWD/environment.cpp \
$$PWD/winutils.cpp \
$$PWD/itemviews.cpp \
$$PWD/treeviewcombobox.cpp \
- $$PWD/proxycredentialsdialog.cpp
+ $$PWD/proxycredentialsdialog.cpp \
+ $$PWD/macroexpander.cpp
win32:SOURCES += $$PWD/consoleprocess_win.cpp
else:SOURCES += $$PWD/consoleprocess_unix.cpp
@@ -185,7 +186,8 @@ HEADERS += \
$$PWD/scopedswap.h \
$$PWD/algorithm.h \
$$PWD/QtConcurrentTools \
- $$PWD/proxycredentialsdialog.h
+ $$PWD/proxycredentialsdialog.h \
+ $$PWD/macroexpander.h
FORMS += $$PWD/filewizardpage.ui \
$$PWD/projectintropage.ui \
diff --git a/src/libs/utils/utils.qbs b/src/libs/utils/utils.qbs
index 3e100f3129..9abcf48d2a 100644
--- a/src/libs/utils/utils.qbs
+++ b/src/libs/utils/utils.qbs
@@ -105,6 +105,8 @@ QtcLibrary {
"linecolumnlabel.cpp",
"linecolumnlabel.h",
"listutils.h",
+ "macroexpander.cpp",
+ "macroexpander.h",
"multitask.h",
"navigationtreeview.cpp",
"navigationtreeview.h",
diff --git a/src/plugins/debugger/debuggerkitinformation.cpp b/src/plugins/debugger/debuggerkitinformation.cpp
index bebc29a3d7..cc563e2e4b 100644
--- a/src/plugins/debugger/debuggerkitinformation.cpp
+++ b/src/plugins/debugger/debuggerkitinformation.cpp
@@ -37,6 +37,7 @@
#include <projectexplorer/kitinformationmacroexpander.h>
#include <utils/fileutils.h>
+#include <utils/macroexpander.h>
#include <utils/qtcassert.h>
#include <QFileInfo>
diff --git a/src/plugins/qtsupport/baseqtversion.cpp b/src/plugins/qtsupport/baseqtversion.cpp
index 6254dcab0a..ba51c1773c 100644
--- a/src/plugins/qtsupport/baseqtversion.cpp
+++ b/src/plugins/qtsupport/baseqtversion.cpp
@@ -47,9 +47,9 @@
#include <utils/algorithm.h>
#include <utils/hostosinfo.h>
+#include <utils/macroexpander.h>
#include <utils/qtcassert.h>
#include <utils/runextensions.h>
-#include <utils/stringutils.h>
#include <utils/synchronousprocess.h>
#include <utils/winutils.h>
#include <utils/algorithm.h>