2009-02-25 09:15:00 +01:00
|
|
|
/**************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
2010-03-05 11:25:49 +01:00
|
|
|
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-06-17 00:01:27 +10:00
|
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Commercial Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Licensees holding valid Qt Commercial licenses may use this file in
|
|
|
|
|
** accordance with the Qt Commercial License Agreement provided with the
|
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
|
|
|
** a written agreement between you and Nokia.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** GNU Lesser General Public License Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** 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.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** If you are unsure which license is appropriate for your use, please
|
2009-08-14 09:30:56 +02:00
|
|
|
** contact the sales department at http://qt.nokia.com/contact.
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
**************************************************************************/
|
2008-12-02 14:09:21 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#ifndef SETTINGSTUTILS_H
|
|
|
|
|
#define SETTINGSTUTILS_H
|
|
|
|
|
|
|
|
|
|
#include "utils_global.h"
|
|
|
|
|
|
2009-11-25 12:34:56 +01:00
|
|
|
QT_BEGIN_NAMESPACE
|
|
|
|
|
class QStringList;
|
|
|
|
|
QT_END_NAMESPACE
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
namespace Utils {
|
|
|
|
|
|
|
|
|
|
// Create a usable settings key from a category,
|
|
|
|
|
// for example Editor|C++ -> Editor_C__
|
2009-05-08 12:09:21 +02:00
|
|
|
QTCREATOR_UTILS_EXPORT QString settingsKey(const QString &category);
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2009-11-25 12:34:56 +01:00
|
|
|
// Return the common prefix part of a string list:
|
|
|
|
|
// "C:\foo\bar1" "C:\foo\bar2" -> "C:\foo\bar"
|
|
|
|
|
QTCREATOR_UTILS_EXPORT QString commonPrefix(const QStringList &strings);
|
|
|
|
|
|
|
|
|
|
// Return the common path of a list of files:
|
|
|
|
|
// "C:\foo\bar1" "C:\foo\bar2" -> "C:\foo"
|
|
|
|
|
QTCREATOR_UTILS_EXPORT QString commonPath(const QStringList &files);
|
|
|
|
|
|
2010-07-13 16:42:36 +02:00
|
|
|
// On Linux/Mac replace user's home path with ~
|
|
|
|
|
// Uses cleaned path and tries to use absolute path of "path" if possible
|
|
|
|
|
// If path is not sub of home path, or when running on Windows, returns the input
|
|
|
|
|
QTCREATOR_UTILS_EXPORT QString withTildeHomePath(const QString &path);
|
|
|
|
|
|
2010-11-08 21:09:19 +01:00
|
|
|
class QTCREATOR_UTILS_EXPORT AbstractMacroExpander {
|
|
|
|
|
public:
|
|
|
|
|
// Not const, as it may change the state of the expander.
|
|
|
|
|
//! Find an expando to replace and provide a replacement string.
|
|
|
|
|
//! \param str The string to scan
|
|
|
|
|
//! \param pos Position to start scan on input, found position on output
|
|
|
|
|
//! \param ret Replacement string on output
|
|
|
|
|
//! \return Length of string part to replace, zero if no (further) matches found
|
|
|
|
|
virtual int findMacro(const QString &str, int *pos, QString *ret) = 0;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class QTCREATOR_UTILS_EXPORT AbstractQtcMacroExpander : public AbstractMacroExpander {
|
|
|
|
|
public:
|
|
|
|
|
virtual int findMacro(const QString &str, int *pos, QString *ret);
|
|
|
|
|
//! Provide a replacement string for an expando
|
|
|
|
|
//! \param name The name of the expando
|
|
|
|
|
//! \param ret Replacement string on output
|
|
|
|
|
//! \return True if the expando was found
|
|
|
|
|
virtual bool resolveMacro(const QString &name, QString *ret) = 0;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
QTCREATOR_UTILS_EXPORT void expandMacros(QString *str, AbstractMacroExpander *mx);
|
|
|
|
|
QTCREATOR_UTILS_EXPORT QString expandMacros(const QString &str, AbstractMacroExpander *mx);
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
} // namespace Utils
|
|
|
|
|
|
|
|
|
|
#endif // SETTINGSTUTILS_H
|