forked from qt-creator/qt-creator
Core: Add a basic extension for the JsExpander
This adds a "Utils" object to the Js runtime offered by the JsExpander that adds some useful functions. Mostly file name mangling and finding preferred extension from the MIME type database. Change-Id: I907dae7f295167667ac2ae81461bbff16dc98ef4 Reviewed-by: Daniel Teske <daniel.teske@digia.com>
This commit is contained in:
@@ -566,13 +566,33 @@ FileName FileName::parentDir() const
|
|||||||
return FileName::fromString(parent);
|
return FileName::fromString(parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Constructs a FileName from \a fileName
|
/// Constructs a FileName from \a filename
|
||||||
/// \a fileName is not checked for validity.
|
/// \a filename is not checked for validity.
|
||||||
FileName FileName::fromString(const QString &filename)
|
FileName FileName::fromString(const QString &filename)
|
||||||
{
|
{
|
||||||
return FileName(filename);
|
return FileName(filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Constructs a FileName from \a fileName. The \a defaultExtension is appended
|
||||||
|
/// to \a filename if that does not have an extension already.
|
||||||
|
/// \a fileName is not checked for validity.
|
||||||
|
FileName FileName::fromString(const QString &filename, const QString &defaultExtension)
|
||||||
|
{
|
||||||
|
if (filename.isEmpty() || defaultExtension.isEmpty())
|
||||||
|
return filename;
|
||||||
|
|
||||||
|
QString rc = filename;
|
||||||
|
QFileInfo fi(filename);
|
||||||
|
// Add extension unless user specified something else
|
||||||
|
const QChar dot = QLatin1Char('.');
|
||||||
|
if (!fi.fileName().contains(dot)) {
|
||||||
|
if (!defaultExtension.startsWith(dot))
|
||||||
|
rc += dot;
|
||||||
|
rc += defaultExtension;
|
||||||
|
}
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
/// Constructs a FileName from \a fileName
|
/// Constructs a FileName from \a fileName
|
||||||
/// \a fileName is not checked for validity.
|
/// \a fileName is not checked for validity.
|
||||||
FileName FileName::fromLatin1(const QByteArray &filename)
|
FileName FileName::fromLatin1(const QByteArray &filename)
|
||||||
|
|||||||
@@ -66,6 +66,7 @@ public:
|
|||||||
explicit FileName(const QFileInfo &info);
|
explicit FileName(const QFileInfo &info);
|
||||||
QFileInfo toFileInfo() const;
|
QFileInfo toFileInfo() const;
|
||||||
static FileName fromString(const QString &filename);
|
static FileName fromString(const QString &filename);
|
||||||
|
static FileName fromString(const QString &filename, const QString &defaultExtension);
|
||||||
static FileName fromLatin1(const QByteArray &filename);
|
static FileName fromLatin1(const QByteArray &filename);
|
||||||
static FileName fromUserInput(const QString &filename);
|
static FileName fromUserInput(const QString &filename);
|
||||||
QString toString() const;
|
QString toString() const;
|
||||||
|
|||||||
121
src/plugins/coreplugin/corejsextensions.cpp
Normal file
121
src/plugins/coreplugin/corejsextensions.cpp
Normal file
@@ -0,0 +1,121 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** 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 "corejsextensions.h"
|
||||||
|
|
||||||
|
#include "mimedatabase.h"
|
||||||
|
|
||||||
|
#include <utils/fileutils.h>
|
||||||
|
#include <utils/qtcassert.h>
|
||||||
|
|
||||||
|
#include <QDir>
|
||||||
|
#include <QTemporaryFile>
|
||||||
|
#include <QVariant>
|
||||||
|
|
||||||
|
namespace Core {
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
|
QString UtilsJsExtension::toNativeSeparators(const QString &in) const
|
||||||
|
{
|
||||||
|
return QDir::toNativeSeparators(in);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::fromNativeSeparators(const QString &in) const
|
||||||
|
{
|
||||||
|
return QDir::fromNativeSeparators(in);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::baseName(const QString &in) const
|
||||||
|
{
|
||||||
|
QFileInfo fi(in);
|
||||||
|
return fi.baseName();
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::completeBaseName(const QString &in) const
|
||||||
|
{
|
||||||
|
QFileInfo fi(in);
|
||||||
|
return fi.completeBaseName();
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::suffix(const QString &in) const
|
||||||
|
{
|
||||||
|
QFileInfo fi(in);
|
||||||
|
return fi.suffix();
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::completeSuffix(const QString &in) const
|
||||||
|
{
|
||||||
|
QFileInfo fi(in);
|
||||||
|
return fi.completeSuffix();
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::path(const QString &in) const
|
||||||
|
{
|
||||||
|
QFileInfo fi(in);
|
||||||
|
return fi.path();
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::absoluteFilePath(const QString &in) const
|
||||||
|
{
|
||||||
|
QFileInfo fi(in);
|
||||||
|
return fi.absoluteFilePath();
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::preferredSuffix(const QString &mimetype) const
|
||||||
|
{
|
||||||
|
return Core::MimeDatabase::preferredSuffixByType(mimetype);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::fileName(const QString &path, const QString &extension) const
|
||||||
|
{
|
||||||
|
return Utils::FileName::fromString(path, extension).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
QString UtilsJsExtension::mktemp(const QString &pattern) const
|
||||||
|
{
|
||||||
|
QString tmp = pattern;
|
||||||
|
if (tmp.isEmpty())
|
||||||
|
tmp = QStringLiteral("qt_temp.XXXXXX");
|
||||||
|
QFileInfo fi(tmp);
|
||||||
|
if (!fi.isAbsolute()) {
|
||||||
|
QString tempPattern = QDir::tempPath();
|
||||||
|
if (!tempPattern.endsWith(QLatin1Char('/')))
|
||||||
|
tempPattern += QLatin1Char('/');
|
||||||
|
tmp = tempPattern + tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
QTemporaryFile file(tmp);
|
||||||
|
file.setAutoRemove(false);
|
||||||
|
QTC_ASSERT(file.open(), return QString());
|
||||||
|
file.close();
|
||||||
|
return file.fileName();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Internal
|
||||||
|
} // namespace Core
|
||||||
74
src/plugins/coreplugin/corejsextensions.h
Normal file
74
src/plugins/coreplugin/corejsextensions.h
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** 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 COREJSEXTENSIONS_H
|
||||||
|
#define COREJSEXTENSIONS_H
|
||||||
|
|
||||||
|
#include <utils/stringutils.h>
|
||||||
|
|
||||||
|
#include <QScriptEngine>
|
||||||
|
#include <QSet>
|
||||||
|
|
||||||
|
namespace Core {
|
||||||
|
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
|
class UtilsJsExtension : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
UtilsJsExtension(QObject *parent = 0) : QObject(parent) { }
|
||||||
|
|
||||||
|
// File name conversions:
|
||||||
|
Q_INVOKABLE QString toNativeSeparators(const QString &in) const;
|
||||||
|
Q_INVOKABLE QString fromNativeSeparators(const QString &in) const;
|
||||||
|
|
||||||
|
Q_INVOKABLE QString baseName(const QString &in) const;
|
||||||
|
Q_INVOKABLE QString completeBaseName(const QString &in) const;
|
||||||
|
Q_INVOKABLE QString suffix(const QString &in) const;
|
||||||
|
Q_INVOKABLE QString completeSuffix(const QString &in) const;
|
||||||
|
Q_INVOKABLE QString path(const QString &in) const;
|
||||||
|
Q_INVOKABLE QString absoluteFilePath(const QString &in) const;
|
||||||
|
|
||||||
|
// MimeDB:
|
||||||
|
Q_INVOKABLE QString preferredSuffix(const QString &mimetype) const;
|
||||||
|
|
||||||
|
// Generate filename:
|
||||||
|
Q_INVOKABLE QString fileName(const QString &path,
|
||||||
|
const QString &extension) const;
|
||||||
|
|
||||||
|
// Generate temporary file:
|
||||||
|
Q_INVOKABLE QString mktemp(const QString &pattern) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace Internal
|
||||||
|
} // namespace Core
|
||||||
|
|
||||||
|
#endif // COREJSEXTENSIONS_H
|
||||||
@@ -8,7 +8,8 @@ QT += help \
|
|||||||
include(../../qtcreatorplugin.pri)
|
include(../../qtcreatorplugin.pri)
|
||||||
include(../../shared/scriptwrapper/scriptwrapper.pri)
|
include(../../shared/scriptwrapper/scriptwrapper.pri)
|
||||||
win32-msvc*:QMAKE_CXXFLAGS += -wd4251 -wd4290 -wd4250
|
win32-msvc*:QMAKE_CXXFLAGS += -wd4251 -wd4290 -wd4250
|
||||||
SOURCES += mainwindow.cpp \
|
SOURCES += corejsextensions.cpp \
|
||||||
|
mainwindow.cpp \
|
||||||
editmode.cpp \
|
editmode.cpp \
|
||||||
iwizardfactory.cpp \
|
iwizardfactory.cpp \
|
||||||
tabpositionindicator.cpp \
|
tabpositionindicator.cpp \
|
||||||
@@ -102,7 +103,8 @@ SOURCES += mainwindow.cpp \
|
|||||||
patchtool.cpp \
|
patchtool.cpp \
|
||||||
windowsupport.cpp
|
windowsupport.cpp
|
||||||
|
|
||||||
HEADERS += mainwindow.h \
|
HEADERS += corejsextensions.h \
|
||||||
|
mainwindow.h \
|
||||||
editmode.h \
|
editmode.h \
|
||||||
iwizardfactory.h \
|
iwizardfactory.h \
|
||||||
tabpositionindicator.h \
|
tabpositionindicator.h \
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ QtcPlugin {
|
|||||||
"core.qrc",
|
"core.qrc",
|
||||||
"core_global.h",
|
"core_global.h",
|
||||||
"coreconstants.h",
|
"coreconstants.h",
|
||||||
|
"corejsextensions.cpp", "corejsextensions.h",
|
||||||
"coreplugin.cpp", "coreplugin.h",
|
"coreplugin.cpp", "coreplugin.h",
|
||||||
"designmode.cpp", "designmode.h",
|
"designmode.cpp", "designmode.h",
|
||||||
"documentmanager.cpp", "documentmanager.h",
|
"documentmanager.cpp", "documentmanager.h",
|
||||||
|
|||||||
@@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
#include "jsexpander.h"
|
#include "jsexpander.h"
|
||||||
|
|
||||||
|
#include "corejsextensions.h"
|
||||||
#include "variablemanager.h"
|
#include "variablemanager.h"
|
||||||
|
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
@@ -43,7 +44,11 @@ namespace Internal {
|
|||||||
|
|
||||||
class JsExpanderPrivate {
|
class JsExpanderPrivate {
|
||||||
public:
|
public:
|
||||||
|
JsExpanderPrivate() : m_utilsExtension(new UtilsJsExtension) { }
|
||||||
|
~JsExpanderPrivate() { delete m_utilsExtension; }
|
||||||
|
|
||||||
QScriptEngine m_engine;
|
QScriptEngine m_engine;
|
||||||
|
UtilsJsExtension *m_utilsExtension;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Internal
|
} // namespace Internal
|
||||||
@@ -98,6 +103,8 @@ JsExpander::JsExpander()
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
registerQObjectForJs(QLatin1String("Util"), d->m_utilsExtension);
|
||||||
}
|
}
|
||||||
|
|
||||||
JsExpander::~JsExpander()
|
JsExpander::~JsExpander()
|
||||||
|
|||||||
@@ -270,7 +270,8 @@ const QStringList &CustomToolChain::cxx11Flags() const
|
|||||||
|
|
||||||
void CustomToolChain::setMkspecs(const QString &specs)
|
void CustomToolChain::setMkspecs(const QString &specs)
|
||||||
{
|
{
|
||||||
m_mkspecs = Utils::transform(specs.split(QLatin1Char(',')), &FileName::fromString);
|
m_mkspecs = Utils::transform(specs.split(QLatin1Char(',')),
|
||||||
|
[](QString fn) { return Utils::FileName::fromString(fn); });
|
||||||
}
|
}
|
||||||
|
|
||||||
QString CustomToolChain::mkspecs() const
|
QString CustomToolChain::mkspecs() const
|
||||||
|
|||||||
Reference in New Issue
Block a user