forked from qt-creator/qt-creator
Merge remote-tracking branch 'origin/2.6'
Conflicts: share/share.qbs src/plugins/cpptools/cppchecksymbols.cpp src/plugins/texteditor/behaviorsettingswidget.cpp Change-Id: Ia34060984f9c036b2f28a6411d796d41f55a3e37
This commit is contained in:
@@ -120,15 +120,15 @@
|
|||||||
custom look and feel and QML and C++ code to implement the
|
custom look and feel and QML and C++ code to implement the
|
||||||
application logic
|
application logic
|
||||||
|
|
||||||
\o Qt Quick Application for MeeGo Harmattan
|
\o Qt Quick 1 Application for MeeGo Harmattan
|
||||||
|
|
||||||
Use Qt Quick Components for MeeGo Harmattan to design a user
|
Use Qt Quick Components for MeeGo Harmattan to design a user
|
||||||
interface with the platform look and feel
|
interface with the platform look and feel
|
||||||
|
|
||||||
\o Qt Quick Application (from Existing QML File)
|
\o Qt Quick 1 Application (from Existing QML File)
|
||||||
|
|
||||||
Convert existing QML applications to projects that you can run
|
Convert existing Qt Quick 1 applications to projects that you
|
||||||
in \QC or deploy to mobile devices
|
can run in \QC or deploy to mobile devices
|
||||||
|
|
||||||
\o Qt Console Application
|
\o Qt Console Application
|
||||||
|
|
||||||
@@ -158,12 +158,18 @@
|
|||||||
|
|
||||||
Shared or static C++ library based on qmake
|
Shared or static C++ library based on qmake
|
||||||
|
|
||||||
\o Custom QML Extension Plugin
|
\o Qt Quick 1 Extension Plugin
|
||||||
|
|
||||||
C++ plugin that makes it possible to offer extensions
|
C++ plugin that makes it possible to offer extensions that can
|
||||||
that can be loaded dynamically into applications by using the
|
be loaded dynamically into Qt Quick 1 applications by using the
|
||||||
QDeclarativeEngine class
|
QDeclarativeEngine class
|
||||||
|
|
||||||
|
\o Qt Quick 2 Extension Plugin
|
||||||
|
|
||||||
|
C++ plugin that makes it possible to offer extensions that can
|
||||||
|
be loaded dynamically into Qt Quick 2 applications by using the
|
||||||
|
QQmlEngine class
|
||||||
|
|
||||||
\o \QC Plugin
|
\o \QC Plugin
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -64,15 +64,17 @@
|
|||||||
need to have the development environment installed on your
|
need to have the development environment installed on your
|
||||||
computer to create and run this type of project.
|
computer to create and run this type of project.
|
||||||
|
|
||||||
\o \gui {Qt Quick Application (from Existing QML File)} converts
|
\o \gui {Qt Quick 1 Application (from Existing QML File)} converts
|
||||||
existing QML applications to Qt Quick application projects. This
|
existing Qt Quick 1 applications to Qt Quick application projects.
|
||||||
enables you to run them from \QC and to deploy them to mobile
|
This enables you to run them from \QC and to deploy them to mobile
|
||||||
devices.
|
devices.
|
||||||
|
|
||||||
\o \gui {Custom QML Extension Plugin} (in the \gui Libraries category)
|
\o \gui {Qt Quick Extension Plugins} (in the \gui Libraries category)
|
||||||
creates a C++ plugin that makes
|
create C++ plugins that make it possible to offer extensions that
|
||||||
it possible to offer extensions that can be loaded dynamically into
|
can be loaded dynamically into Qt Quick applications. Select
|
||||||
applications by using the QDeclarativeEngine class.
|
\gui {Qt Quick 1 Extension Plugin} to create extensions for
|
||||||
|
Qt Quick 1 applications and \gui {Qt Quick 2 Extension Plugin} to
|
||||||
|
create extensions for Qt Quick 2 applications.
|
||||||
|
|
||||||
\endlist
|
\endlist
|
||||||
|
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 1.2 KiB |
@@ -0,0 +1,14 @@
|
|||||||
|
#include "%ProjectName:l%_plugin.%CppHeaderSuffix%"
|
||||||
|
#include "%ObjectName:l%.%CppHeaderSuffix%"
|
||||||
|
|
||||||
|
#include <qdeclarative.h>
|
||||||
|
|
||||||
|
void %ProjectName:s%Plugin::registerTypes(const char *uri)
|
||||||
|
{
|
||||||
|
// @uri %Uri%
|
||||||
|
qmlRegisterType<%ObjectName%>(uri, 1, 0, "%ObjectName%");
|
||||||
|
}
|
||||||
|
|
||||||
|
#if QT_VERSION < 0x050000
|
||||||
|
Q_EXPORT_PLUGIN2(%ProjectName:s%, %ProjectName:s%Plugin)
|
||||||
|
#endif
|
||||||
@@ -6,6 +6,9 @@
|
|||||||
class %ProjectName:s%Plugin : public QDeclarativeExtensionPlugin
|
class %ProjectName:s%Plugin : public QDeclarativeExtensionPlugin
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
#if QT_VERSION >= 0x050000
|
||||||
|
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QQmlExtensionInterface")
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void registerTypes(const char *uri);
|
void registerTypes(const char *uri);
|
||||||
@@ -36,11 +36,11 @@ leave room for the Qt 4 target page.
|
|||||||
-->
|
-->
|
||||||
<wizard version="1" kind="project"
|
<wizard version="1" kind="project"
|
||||||
class="qt4project" firstpage="10"
|
class="qt4project" firstpage="10"
|
||||||
id="QmlExtensionPlugin" category="G.Libraries"
|
id="QtQuick1ExtensionPlugin" category="G.Libraries"
|
||||||
featuresRequired="QtSupport.Wizards.FeatureQtQuick,QtSupport.Wizards.FeatureQtQuick.1">
|
featuresRequired="QtSupport.Wizards.FeatureQtQuick,QtSupport.Wizards.FeatureQtQuick.1">
|
||||||
<icon>lib.png</icon>
|
<icon>lib.png</icon>
|
||||||
<description>Creates a C++ plugin that makes it possible to offer extensions that can be loaded dynamically into applications using the QDeclarativeEngine class.</description>
|
<description>Creates a C++ plugin that makes it possible to offer extensions that can be loaded dynamically into applications using the QDeclarativeEngine class.</description>
|
||||||
<displayname>Custom QML Extension Plugin</displayname>
|
<displayname>Qt Quick 1 Extension Plugin</displayname>
|
||||||
<displaycategory>Libraries</displaycategory>
|
<displaycategory>Libraries</displaycategory>
|
||||||
<files>
|
<files>
|
||||||
<file source="qmldir" target="qmldir"/>
|
<file source="qmldir" target="qmldir"/>
|
||||||
BIN
share/qtcreator/templates/wizards/qtquick2-extension/lib.png
Normal file
BIN
share/qtcreator/templates/wizards/qtquick2-extension/lib.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.2 KiB |
@@ -0,0 +1,15 @@
|
|||||||
|
#include "%ObjectName:l%.%CppHeaderSuffix%"
|
||||||
|
|
||||||
|
%ObjectName%::%ObjectName%(QQuickItem *parent):
|
||||||
|
QQuickItem(parent)
|
||||||
|
{
|
||||||
|
// By default, QQuickItem does not draw anything. If you subclass
|
||||||
|
// QQuickItem to create a visual item, you will need to uncomment the
|
||||||
|
// following line and re-implement updatePaintNode()
|
||||||
|
|
||||||
|
// setFlag(ItemHasContents, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
%ObjectName%::~%ObjectName%()
|
||||||
|
{
|
||||||
|
}
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
#ifndef %ObjectName:u%_H
|
||||||
|
#define %ObjectName:u%_H
|
||||||
|
|
||||||
|
#include <QQuickItem>
|
||||||
|
|
||||||
|
class %ObjectName% : public QQuickItem
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
Q_DISABLE_COPY(%ObjectName%)
|
||||||
|
|
||||||
|
public:
|
||||||
|
%ObjectName%(QQuickItem *parent = 0);
|
||||||
|
~%ObjectName%();
|
||||||
|
};
|
||||||
|
|
||||||
|
QML_DECLARE_TYPE(%ObjectName%)
|
||||||
|
|
||||||
|
#endif // %ObjectName:u%_H
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
#include "%ProjectName:l%_plugin.%CppHeaderSuffix%"
|
#include "%ProjectName:l%_plugin.%CppHeaderSuffix%"
|
||||||
#include "%ObjectName:l%.%CppHeaderSuffix%"
|
#include "%ObjectName:l%.%CppHeaderSuffix%"
|
||||||
|
|
||||||
#include <qdeclarative.h>
|
#include <qqml.h>
|
||||||
|
|
||||||
void %ProjectName:s%Plugin::registerTypes(const char *uri)
|
void %ProjectName:s%Plugin::registerTypes(const char *uri)
|
||||||
{
|
{
|
||||||
@@ -9,4 +9,3 @@ void %ProjectName:s%Plugin::registerTypes(const char *uri)
|
|||||||
qmlRegisterType<%ObjectName%>(uri, 1, 0, "%ObjectName%");
|
qmlRegisterType<%ObjectName%>(uri, 1, 0, "%ObjectName%");
|
||||||
}
|
}
|
||||||
|
|
||||||
Q_EXPORT_PLUGIN2(%ProjectName:s%, %ProjectName:s%Plugin)
|
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
#ifndef %ProjectName:h%_PLUGIN_H
|
||||||
|
#define %ProjectName:h%_PLUGIN_H
|
||||||
|
|
||||||
|
#include <QQmlExtensionPlugin>
|
||||||
|
|
||||||
|
class %ProjectName:s%Plugin : public QQmlExtensionPlugin
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QQmlExtensionInterface")
|
||||||
|
|
||||||
|
public:
|
||||||
|
void registerTypes(const char *uri);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // %ProjectName:h%_PLUGIN_H
|
||||||
@@ -0,0 +1,34 @@
|
|||||||
|
TEMPLATE = lib
|
||||||
|
TARGET = %ProjectName%
|
||||||
|
QT += qml quick
|
||||||
|
CONFIG += qt plugin
|
||||||
|
|
||||||
|
TARGET = $$qtLibraryTarget($$TARGET)
|
||||||
|
uri = %Uri%
|
||||||
|
|
||||||
|
# Input
|
||||||
|
SOURCES += \
|
||||||
|
%ProjectName:l%_plugin.%CppSourceSuffix% \
|
||||||
|
%ObjectName:l%.%CppSourceSuffix%
|
||||||
|
|
||||||
|
HEADERS += \
|
||||||
|
%ProjectName:l%_plugin.%CppHeaderSuffix% \
|
||||||
|
%ObjectName:l%.%CppHeaderSuffix%
|
||||||
|
|
||||||
|
OTHER_FILES = qmldir
|
||||||
|
|
||||||
|
!equals(_PRO_FILE_PWD_, $$OUT_PWD) {
|
||||||
|
copy_qmldir.target = $$OUT_PWD/qmldir
|
||||||
|
copy_qmldir.depends = $$_PRO_FILE_PWD_/qmldir
|
||||||
|
copy_qmldir.commands = $(COPY_FILE) \"$$replace(copy_qmldir.depends, /, $$QMAKE_DIR_SEP)\" \"$$replace(copy_qmldir.target, /, $$QMAKE_DIR_SEP)\"
|
||||||
|
QMAKE_EXTRA_TARGETS += copy_qmldir
|
||||||
|
PRE_TARGETDEPS += $$copy_qmldir.target
|
||||||
|
}
|
||||||
|
|
||||||
|
qmldir.files = qmldir
|
||||||
|
unix {
|
||||||
|
installPath = $$[QT_INSTALL_IMPORTS]/$$replace(uri, \\., /)
|
||||||
|
qmldir.path = $$installPath
|
||||||
|
target.path = $$installPath
|
||||||
|
INSTALLS += target qmldir
|
||||||
|
}
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
module %Uri%
|
||||||
|
plugin %ProjectName%
|
||||||
@@ -0,0 +1,70 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2012 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.
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
Custom project wizard configuration example file. Note that by convention,
|
||||||
|
the project file goes last.
|
||||||
|
The "class" and "firstpage" attributes specify that it is a Qt 4 wizard and
|
||||||
|
leave room for the Qt 4 target page.
|
||||||
|
-->
|
||||||
|
<wizard version="1" kind="project"
|
||||||
|
class="qt4project" firstpage="10"
|
||||||
|
id="QtQuick2ExtensionPlugin" category="G.Libraries"
|
||||||
|
featuresRequired="QtSupport.Wizards.FeatureQtQuick,QtSupport.Wizards.FeatureQtQuick.2">
|
||||||
|
<icon>lib.png</icon>
|
||||||
|
<description>Creates a C++ plugin that makes it possible to offer extensions that can be loaded dynamically into applications using the QQmlEngine class.</description>
|
||||||
|
<displayname>Qt Quick 2 Extension Plugin</displayname>
|
||||||
|
<displaycategory>Libraries</displaycategory>
|
||||||
|
<files>
|
||||||
|
<file source="qmldir" target="qmldir"/>
|
||||||
|
<file source="plugin.h" target="%ProjectName:l%_plugin.%CppHeaderSuffix%"/>
|
||||||
|
<file source="plugin.cpp" target="%ProjectName:l%_plugin.%CppSourceSuffix%"/>
|
||||||
|
<file source="object.h" target="%ObjectName:l%.%CppHeaderSuffix%"/>
|
||||||
|
<file source="object.cpp" target="%ObjectName:l%.%CppSourceSuffix%" openeditor="true"/>
|
||||||
|
<file source="project.pro" target="%ProjectName:l%.pro" openproject="true"/>
|
||||||
|
</files>
|
||||||
|
<!-- Create a 2nd wizard page with parameters -->
|
||||||
|
<fieldpagetitle>Custom QML Extension Plugin Parameters</fieldpagetitle>
|
||||||
|
<fields>
|
||||||
|
<field mandatory="true" name="ObjectName">
|
||||||
|
<fieldcontrol class="QLineEdit" validator='^[A-Za-z0-9_]+$' defaulttext="MyItem"/>
|
||||||
|
<fielddescription>Object Class-name:</fielddescription>
|
||||||
|
</field>
|
||||||
|
<field mandatory="true" name="Uri">
|
||||||
|
<fieldcontrol class="QLineEdit" validator='^[A-Za-z0-9]+([A-Za-z0-9-]*[A-Za-z0-9]+)?(\.[A-Za-z0-9]+([-A-Za-z0-9]*[A-Za-z0-9]+)?)*$' defaulttext="com.mycompany.qmlcomponents"/>
|
||||||
|
<fielddescription>URI:</fielddescription>
|
||||||
|
</field>
|
||||||
|
</fields>
|
||||||
|
<validationrules>
|
||||||
|
<validationrule condition='"%ObjectName%" != "%ProjectName%_plugin"'>
|
||||||
|
<message>The project name and the object class-name cannot be the same.</message>
|
||||||
|
</validationrule>
|
||||||
|
</validationrules>
|
||||||
|
</wizard>
|
||||||
@@ -19,8 +19,6 @@ Product {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Group {
|
Group {
|
||||||
condition: qbs.targetOS == "macx"
|
|
||||||
qbs.installDir: "share/qtcreator/scripts"
|
|
||||||
fileTags: ["install"]
|
fileTags: ["install"]
|
||||||
files: "qtcreator/scripts/openTerminal.command"
|
files: "qtcreator/scripts/openTerminal.command"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -359,7 +359,11 @@ int main(int argc, char **argv)
|
|||||||
const QString &creatorTrPath = QCoreApplication::applicationDirPath()
|
const QString &creatorTrPath = QCoreApplication::applicationDirPath()
|
||||||
+ QLatin1String(SHARE_PATH "/translations");
|
+ QLatin1String(SHARE_PATH "/translations");
|
||||||
foreach (QString locale, uiLanguages) {
|
foreach (QString locale, uiLanguages) {
|
||||||
|
#if (QT_VERSION >= 0x050000)
|
||||||
|
locale = QLocale(locale).name();
|
||||||
|
#else
|
||||||
locale.replace(QLatin1Char('-'), QLatin1Char('_')); // work around QTBUG-25973
|
locale.replace(QLatin1Char('-'), QLatin1Char('_')); // work around QTBUG-25973
|
||||||
|
#endif
|
||||||
if (translator.load(QLatin1String("qtcreator_") + locale, creatorTrPath)) {
|
if (translator.load(QLatin1String("qtcreator_") + locale, creatorTrPath)) {
|
||||||
const QString &qtTrPath = QLibraryInfo::location(QLibraryInfo::TranslationsPath);
|
const QString &qtTrPath = QLibraryInfo::location(QLibraryInfo::TranslationsPath);
|
||||||
const QString &qtTrFile = QLatin1String("qt_") + locale;
|
const QString &qtTrFile = QLatin1String("qt_") + locale;
|
||||||
|
|||||||
@@ -70,6 +70,8 @@ BaseTreeView::BaseTreeView(QWidget *parent)
|
|||||||
|
|
||||||
connect(this, SIGNAL(activated(QModelIndex)),
|
connect(this, SIGNAL(activated(QModelIndex)),
|
||||||
SLOT(rowActivatedHelper(QModelIndex)));
|
SLOT(rowActivatedHelper(QModelIndex)));
|
||||||
|
connect(this, SIGNAL(clicked(QModelIndex)),
|
||||||
|
SLOT(rowClickedHelper(QModelIndex)));
|
||||||
connect(header(), SIGNAL(sectionClicked(int)),
|
connect(header(), SIGNAL(sectionClicked(int)),
|
||||||
SLOT(headerSectionClicked(int)));
|
SLOT(headerSectionClicked(int)));
|
||||||
|
|
||||||
|
|||||||
@@ -49,6 +49,7 @@ public:
|
|||||||
|
|
||||||
void setModel(QAbstractItemModel *model);
|
void setModel(QAbstractItemModel *model);
|
||||||
virtual void rowActivated(const QModelIndex &) {}
|
virtual void rowActivated(const QModelIndex &) {}
|
||||||
|
virtual void rowClicked(const QModelIndex &) {}
|
||||||
void mousePressEvent(QMouseEvent *ev);
|
void mousePressEvent(QMouseEvent *ev);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
@@ -61,6 +62,7 @@ protected slots:
|
|||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void rowActivatedHelper(const QModelIndex &index) { rowActivated(index); }
|
void rowActivatedHelper(const QModelIndex &index) { rowActivated(index); }
|
||||||
|
void rowClickedHelper(const QModelIndex &index) { rowClicked(index); }
|
||||||
void headerSectionClicked(int logicalIndex);
|
void headerSectionClicked(int logicalIndex);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|||||||
@@ -1274,9 +1274,13 @@ IEditor *EditorManager::openEditor(Core::Internal::EditorView *view, const QStri
|
|||||||
qDebug() << Q_FUNC_INFO << fileName << editorId.name();
|
qDebug() << Q_FUNC_INFO << fileName << editorId.name();
|
||||||
|
|
||||||
QString fn = fileName;
|
QString fn = fileName;
|
||||||
|
QFileInfo fi(fn);
|
||||||
int lineNumber = -1;
|
int lineNumber = -1;
|
||||||
if (flags && EditorManager::CanContainLineNumber)
|
if ((flags & EditorManager::CanContainLineNumber) && !fi.exists()) {
|
||||||
lineNumber = extractLineNumber(&fn);
|
lineNumber = extractLineNumber(&fn);
|
||||||
|
if (lineNumber != -1)
|
||||||
|
fi.setFile(fn);
|
||||||
|
}
|
||||||
|
|
||||||
if (fn.isEmpty())
|
if (fn.isEmpty())
|
||||||
return 0;
|
return 0;
|
||||||
@@ -1287,13 +1291,12 @@ IEditor *EditorManager::openEditor(Core::Internal::EditorView *view, const QStri
|
|||||||
const QList<IEditor *> editors = editorsForFileName(fn);
|
const QList<IEditor *> editors = editorsForFileName(fn);
|
||||||
if (!editors.isEmpty()) {
|
if (!editors.isEmpty()) {
|
||||||
IEditor *editor = editors.first();
|
IEditor *editor = editors.first();
|
||||||
if (flags && EditorManager::CanContainLineNumber)
|
if (flags & EditorManager::CanContainLineNumber)
|
||||||
editor->gotoLine(lineNumber, -1);
|
editor->gotoLine(lineNumber, -1);
|
||||||
return activateEditor(view, editor, flags);
|
return activateEditor(view, editor, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString realFn = autoSaveName(fn);
|
QString realFn = autoSaveName(fn);
|
||||||
QFileInfo fi(fn);
|
|
||||||
QFileInfo rfi(realFn);
|
QFileInfo rfi(realFn);
|
||||||
if (!fi.exists() || !rfi.exists() || fi.lastModified() >= rfi.lastModified()) {
|
if (!fi.exists() || !rfi.exists() || fi.lastModified() >= rfi.lastModified()) {
|
||||||
QFile::remove(realFn);
|
QFile::remove(realFn);
|
||||||
@@ -1327,7 +1330,7 @@ IEditor *EditorManager::openEditor(Core::Internal::EditorView *view, const QStri
|
|||||||
if (editor == result)
|
if (editor == result)
|
||||||
restoreEditorState(editor);
|
restoreEditorState(editor);
|
||||||
|
|
||||||
if (flags && EditorManager::CanContainLineNumber)
|
if (flags & EditorManager::CanContainLineNumber)
|
||||||
editor->gotoLine(lineNumber, -1);
|
editor->gotoLine(lineNumber, -1);
|
||||||
|
|
||||||
QApplication::restoreOverrideCursor();
|
QApplication::restoreOverrideCursor();
|
||||||
|
|||||||
@@ -509,9 +509,11 @@ bool CheckSymbols::visit(SimpleDeclarationAST *ast)
|
|||||||
// Add a diagnostic message if non-virtual function has override/final marker
|
// Add a diagnostic message if non-virtual function has override/final marker
|
||||||
if ((_usages.back().kind != SemanticInfo::VirtualMethodUse)) {
|
if ((_usages.back().kind != SemanticInfo::VirtualMethodUse)) {
|
||||||
if (funTy->isOverride())
|
if (funTy->isOverride())
|
||||||
warning(declrIdNameAST, QCoreApplication::translate("CPlusplus::CheckSymbols", "Only virtual methods can be marked `override'"));
|
warning(declrIdNameAST, QCoreApplication::translate(
|
||||||
|
"CPlusplus::CheckSymbols", "Only virtual methods can be marked `override'"));
|
||||||
else if (funTy->isFinal())
|
else if (funTy->isFinal())
|
||||||
warning(declrIdNameAST, QCoreApplication::translate("CPlusPlus::CheckSymbols", "Only virtual methods can be marked `final'"));
|
warning(declrIdNameAST, QCoreApplication::translate(
|
||||||
|
"CPlusPlus::CheckSymbols", "Only virtual methods can be marked `final'"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1415,6 +1415,10 @@ void DebuggerEngine::updateWatchData(const WatchData &, const WatchUpdateFlags &
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DebuggerEngine::watchDataSelected(const QByteArray &iname)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
void DebuggerEngine::watchPoint(const QPoint &)
|
void DebuggerEngine::watchPoint(const QPoint &)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -149,6 +149,8 @@ public:
|
|||||||
|
|
||||||
virtual void updateWatchData(const Internal::WatchData &data,
|
virtual void updateWatchData(const Internal::WatchData &data,
|
||||||
const Internal::WatchUpdateFlags & flags = Internal::WatchUpdateFlags());
|
const Internal::WatchUpdateFlags & flags = Internal::WatchUpdateFlags());
|
||||||
|
virtual void watchDataSelected(const QByteArray &iname);
|
||||||
|
|
||||||
virtual void startDebugger(DebuggerRunControl *runControl);
|
virtual void startDebugger(DebuggerRunControl *runControl);
|
||||||
|
|
||||||
virtual void watchPoint(const QPoint &);
|
virtual void watchPoint(const QPoint &);
|
||||||
|
|||||||
@@ -34,6 +34,7 @@
|
|||||||
#include "stackhandler.h"
|
#include "stackhandler.h"
|
||||||
#include "qmlengine.h"
|
#include "qmlengine.h"
|
||||||
#include "watchdata.h"
|
#include "watchdata.h"
|
||||||
|
#include "watchhandler.h"
|
||||||
|
|
||||||
#include <coreplugin/icore.h>
|
#include <coreplugin/icore.h>
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
@@ -135,6 +136,13 @@ void QmlCppEngine::updateWatchData(const WatchData &data,
|
|||||||
d->m_activeEngine->updateWatchData(data, flags);
|
d->m_activeEngine->updateWatchData(data, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void QmlCppEngine::watchDataSelected(const QByteArray &iname)
|
||||||
|
{
|
||||||
|
const WatchData *wd = watchHandler()->findData(iname);
|
||||||
|
if (wd && wd->isInspect())
|
||||||
|
d->m_qmlEngine->watchDataSelected(iname);
|
||||||
|
}
|
||||||
|
|
||||||
void QmlCppEngine::watchPoint(const QPoint &point)
|
void QmlCppEngine::watchPoint(const QPoint &point)
|
||||||
{
|
{
|
||||||
d->m_cppEngine->watchPoint(point);
|
d->m_cppEngine->watchPoint(point);
|
||||||
|
|||||||
@@ -50,6 +50,7 @@ public:
|
|||||||
TextEditor::ITextEditor * editor, const DebuggerToolTipContext &);
|
TextEditor::ITextEditor * editor, const DebuggerToolTipContext &);
|
||||||
void updateWatchData(const WatchData &data,
|
void updateWatchData(const WatchData &data,
|
||||||
const WatchUpdateFlags &flags);
|
const WatchUpdateFlags &flags);
|
||||||
|
void watchDataSelected(const QByteArray &iname);
|
||||||
|
|
||||||
void watchPoint(const QPoint &);
|
void watchPoint(const QPoint &);
|
||||||
void fetchMemory(MemoryAgent *, QObject *, quint64 addr, quint64 length);
|
void fetchMemory(MemoryAgent *, QObject *, quint64 addr, quint64 length);
|
||||||
|
|||||||
@@ -1026,6 +1026,13 @@ void QmlEngine::updateWatchData(const WatchData &data,
|
|||||||
watchHandler()->insertData(data);
|
watchHandler()->insertData(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void QmlEngine::watchDataSelected(const QByteArray &iname)
|
||||||
|
{
|
||||||
|
const WatchData *wd = watchHandler()->findData(iname);
|
||||||
|
if (wd && wd->isInspect())
|
||||||
|
m_inspectorAdapter.agent()->watchDataSelected(wd);
|
||||||
|
}
|
||||||
|
|
||||||
void QmlEngine::synchronizeWatchers()
|
void QmlEngine::synchronizeWatchers()
|
||||||
{
|
{
|
||||||
QStringList watchedExpressions = watchHandler()->watchedExpressions();
|
QStringList watchedExpressions = watchHandler()->watchedExpressions();
|
||||||
|
|||||||
@@ -162,6 +162,7 @@ private:
|
|||||||
bool supportsThreads() const { return false; }
|
bool supportsThreads() const { return false; }
|
||||||
void updateWatchData(const WatchData &data,
|
void updateWatchData(const WatchData &data,
|
||||||
const WatchUpdateFlags &flags);
|
const WatchUpdateFlags &flags);
|
||||||
|
void watchDataSelected(const QByteArray &iname);
|
||||||
void executeDebuggerCommand(const QString &command, DebuggerLanguages languages);
|
void executeDebuggerCommand(const QString &command, DebuggerLanguages languages);
|
||||||
bool evaluateScript(const QString &expression);
|
bool evaluateScript(const QString &expression);
|
||||||
|
|
||||||
|
|||||||
@@ -81,6 +81,8 @@ QmlInspectorAdapter::QmlInspectorAdapter(QmlAdapter *debugAdapter,
|
|||||||
{
|
{
|
||||||
connect(m_agent, SIGNAL(objectFetched(QmlDebug::ObjectReference)),
|
connect(m_agent, SIGNAL(objectFetched(QmlDebug::ObjectReference)),
|
||||||
SLOT(onObjectFetched(QmlDebug::ObjectReference)));
|
SLOT(onObjectFetched(QmlDebug::ObjectReference)));
|
||||||
|
connect(m_agent, SIGNAL(jumpToObjectDefinition(QmlDebug::FileReference)),
|
||||||
|
SLOT(jumpToObjectDefinitionInEditor(QmlDebug::FileReference)));
|
||||||
|
|
||||||
QmlDebugConnection *connection = m_debugAdapter->connection();
|
QmlDebugConnection *connection = m_debugAdapter->connection();
|
||||||
DeclarativeEngineDebugClient *engineClient1
|
DeclarativeEngineDebugClient *engineClient1
|
||||||
@@ -473,7 +475,7 @@ void QmlInspectorAdapter::showConnectionStatusMessage(const QString &message)
|
|||||||
m_engine->showMessage(_("QML Inspector: ") + message, LogStatus);
|
m_engine->showMessage(_("QML Inspector: ") + message, LogStatus);
|
||||||
}
|
}
|
||||||
|
|
||||||
void QmlInspectorAdapter::gotoObjectReferenceDefinition(
|
void QmlInspectorAdapter::jumpToObjectDefinitionInEditor(
|
||||||
const FileReference &objSource)
|
const FileReference &objSource)
|
||||||
{
|
{
|
||||||
if (m_cursorPositionChangedExternally) {
|
if (m_cursorPositionChangedExternally) {
|
||||||
@@ -508,7 +510,7 @@ void QmlInspectorAdapter::selectObject(const ObjectReference &obj,
|
|||||||
QList<ObjectReference>() << obj);
|
QList<ObjectReference>() << obj);
|
||||||
|
|
||||||
if (target == EditorTarget)
|
if (target == EditorTarget)
|
||||||
gotoObjectReferenceDefinition(obj.source());
|
jumpToObjectDefinitionInEditor(obj.source());
|
||||||
|
|
||||||
agent()->selectObjectInTree(obj.debugId());
|
agent()->selectObjectInTree(obj.debugId());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -96,6 +96,7 @@ private slots:
|
|||||||
void onReload();
|
void onReload();
|
||||||
void onReloaded();
|
void onReloaded();
|
||||||
void onDestroyedObject(int);
|
void onDestroyedObject(int);
|
||||||
|
void jumpToObjectDefinitionInEditor(const QmlDebug::FileReference &objSource);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setActiveEngineClient(QmlDebug::BaseEngineDebugClient *client);
|
void setActiveEngineClient(QmlDebug::BaseEngineDebugClient *client);
|
||||||
@@ -103,8 +104,6 @@ private:
|
|||||||
void initializePreviews();
|
void initializePreviews();
|
||||||
void showConnectionStatusMessage(const QString &message);
|
void showConnectionStatusMessage(const QString &message);
|
||||||
|
|
||||||
void gotoObjectReferenceDefinition(const QmlDebug::FileReference &objSource);
|
|
||||||
|
|
||||||
enum SelectionTarget { NoTarget, ToolTarget, EditorTarget };
|
enum SelectionTarget { NoTarget, ToolTarget, EditorTarget };
|
||||||
void selectObject(
|
void selectObject(
|
||||||
const QmlDebug::ObjectReference &objectReference,
|
const QmlDebug::ObjectReference &objectReference,
|
||||||
|
|||||||
@@ -121,6 +121,17 @@ void QmlInspectorAgent::updateWatchData(const WatchData &data)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void QmlInspectorAgent::watchDataSelected(const WatchData *data)
|
||||||
|
{
|
||||||
|
if (debug)
|
||||||
|
qDebug() << __FUNCTION__ << '(' << data->id << ')';
|
||||||
|
|
||||||
|
if (data->id) {
|
||||||
|
QTC_ASSERT(m_debugIdLocations.keys().contains(data->id), return);
|
||||||
|
emit jumpToObjectDefinition(m_debugIdLocations.value(data->id));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool QmlInspectorAgent::selectObjectInTree(int debugId)
|
bool QmlInspectorAgent::selectObjectInTree(int debugId)
|
||||||
{
|
{
|
||||||
if (debug) {
|
if (debug) {
|
||||||
|
|||||||
@@ -60,6 +60,7 @@ public:
|
|||||||
|
|
||||||
void assignValue(const WatchData *data, const QString &expression, const QVariant &valueV);
|
void assignValue(const WatchData *data, const QString &expression, const QVariant &valueV);
|
||||||
void updateWatchData(const WatchData &data);
|
void updateWatchData(const WatchData &data);
|
||||||
|
void watchDataSelected(const WatchData *data);
|
||||||
bool selectObjectInTree(int debugId);
|
bool selectObjectInTree(int debugId);
|
||||||
|
|
||||||
quint32 setBindingForObject(int objectDebugId,
|
quint32 setBindingForObject(int objectDebugId,
|
||||||
@@ -101,6 +102,7 @@ signals:
|
|||||||
void propertyChanged(int debugId, const QByteArray &propertyName,
|
void propertyChanged(int debugId, const QByteArray &propertyName,
|
||||||
const QVariant &propertyValue);
|
const QVariant &propertyValue);
|
||||||
void automaticUpdateFailed();
|
void automaticUpdateFailed();
|
||||||
|
void jumpToObjectDefinition(const QmlDebug::FileReference &objSource);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void updateStatus();
|
void updateStatus();
|
||||||
|
|||||||
@@ -992,6 +992,11 @@ void WatchTreeView::setModel(QAbstractItemModel *model)
|
|||||||
SLOT(handleItemIsExpanded(QModelIndex)));
|
SLOT(handleItemIsExpanded(QModelIndex)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void WatchTreeView::rowClicked(const QModelIndex &index)
|
||||||
|
{
|
||||||
|
currentEngine()->watchDataSelected(currentEngine()->watchHandler()->watchData(index)->iname);
|
||||||
|
}
|
||||||
|
|
||||||
void WatchTreeView::handleItemIsExpanded(const QModelIndex &idx)
|
void WatchTreeView::handleItemIsExpanded(const QModelIndex &idx)
|
||||||
{
|
{
|
||||||
bool on = idx.data(LocalsExpandedRole).toBool();
|
bool on = idx.data(LocalsExpandedRole).toBool();
|
||||||
|
|||||||
@@ -51,6 +51,7 @@ public:
|
|||||||
explicit WatchTreeView(Type type, QWidget *parent = 0);
|
explicit WatchTreeView(Type type, QWidget *parent = 0);
|
||||||
Type type() const { return m_type; }
|
Type type() const { return m_type; }
|
||||||
void setModel(QAbstractItemModel *model);
|
void setModel(QAbstractItemModel *model);
|
||||||
|
void rowClicked(const QModelIndex &index);
|
||||||
void reset();
|
void reset();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
|||||||
@@ -341,14 +341,14 @@ bool MaemoMakeInstallToSysrootStep::init()
|
|||||||
const Qt4BuildConfiguration * const bc
|
const Qt4BuildConfiguration * const bc
|
||||||
= qobject_cast<Qt4BuildConfiguration *>(target()->activeBuildConfiguration());
|
= qobject_cast<Qt4BuildConfiguration *>(target()->activeBuildConfiguration());
|
||||||
if (!bc) {
|
if (!bc) {
|
||||||
addOutput("Cannot deploy: No active build dconfiguration.",
|
addOutput(tr("Cannot deploy: No active build dconfiguration."),
|
||||||
ErrorMessageOutput);
|
ErrorMessageOutput);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
const QtSupport::BaseQtVersion *const qtVersion
|
const QtSupport::BaseQtVersion *const qtVersion
|
||||||
= QtSupport::QtKitInformation::qtVersion(target()->kit());
|
= QtSupport::QtKitInformation::qtVersion(target()->kit());
|
||||||
if (!qtVersion) {
|
if (!qtVersion) {
|
||||||
addOutput("Cannot deploy: Unusable build configuration.",
|
addOutput(tr("Cannot deploy: Unusable build configuration."),
|
||||||
ErrorMessageOutput);
|
ErrorMessageOutput);
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|||||||
@@ -87,7 +87,7 @@ MaemoQemuManager::MaemoQemuManager(QObject *parent)
|
|||||||
m_qemuStarterIcon.addFile(":/qt-maemo/images/qemu-stop.png", iconSize,
|
m_qemuStarterIcon.addFile(":/qt-maemo/images/qemu-stop.png", iconSize,
|
||||||
QIcon::Normal, QIcon::On);
|
QIcon::Normal, QIcon::On);
|
||||||
|
|
||||||
m_qemuAction = new QAction("MeeGo Emulator", this);
|
m_qemuAction = new QAction(tr("MeeGo Emulator"), this);
|
||||||
m_qemuAction->setIcon(m_qemuStarterIcon.pixmap(iconSize));
|
m_qemuAction->setIcon(m_qemuStarterIcon.pixmap(iconSize));
|
||||||
m_qemuAction->setToolTip(tr("Start MeeGo Emulator"));
|
m_qemuAction->setToolTip(tr("Start MeeGo Emulator"));
|
||||||
connect(m_qemuAction, SIGNAL(triggered()), this, SLOT(startRuntime()));
|
connect(m_qemuAction, SIGNAL(triggered()), this, SLOT(startRuntime()));
|
||||||
|
|||||||
@@ -68,7 +68,7 @@ void QmlJSPreviewRunner::run(const QString &filename)
|
|||||||
Utils::QtcProcess::quoteArg(filename));
|
Utils::QtcProcess::quoteArg(filename));
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
errorMessage = "No file specified.";
|
errorMessage = tr("No file specified.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!errorMessage.isEmpty())
|
if (!errorMessage.isEmpty())
|
||||||
|
|||||||
@@ -124,7 +124,7 @@ void GenericLinuxDeviceTester::handleConnected()
|
|||||||
d->process = d->connection->createRemoteProcess("uname -rsm");
|
d->process = d->connection->createRemoteProcess("uname -rsm");
|
||||||
connect(d->process.data(), SIGNAL(closed(int)), SLOT(handleProcessFinished(int)));
|
connect(d->process.data(), SIGNAL(closed(int)), SLOT(handleProcessFinished(int)));
|
||||||
|
|
||||||
emit progressMessage("Checking kernel version...");
|
emit progressMessage(tr("Checking kernel version..."));
|
||||||
d->state = RunningUname;
|
d->state = RunningUname;
|
||||||
d->process->start();
|
d->process->start();
|
||||||
}
|
}
|
||||||
@@ -172,7 +172,7 @@ void GenericLinuxDeviceTester::handlePortListReady()
|
|||||||
QTC_ASSERT(d->state == TestingPorts, return);
|
QTC_ASSERT(d->state == TestingPorts, return);
|
||||||
|
|
||||||
if (d->portsGatherer.usedPorts().isEmpty()) {
|
if (d->portsGatherer.usedPorts().isEmpty()) {
|
||||||
emit progressMessage("All specified ports are available.\n");
|
emit progressMessage(tr("All specified ports are available.\n"));
|
||||||
} else {
|
} else {
|
||||||
QString portList;
|
QString portList;
|
||||||
foreach (const int port, d->portsGatherer.usedPorts())
|
foreach (const int port, d->portsGatherer.usedPorts())
|
||||||
|
|||||||
@@ -110,7 +110,7 @@ void PackageUploader::handleSftpChannelInitialized()
|
|||||||
setState(Inactive);
|
setState(Inactive);
|
||||||
emit uploadFinished(tr("Package upload failed: Could not open file."));
|
emit uploadFinished(tr("Package upload failed: Could not open file."));
|
||||||
} else {
|
} else {
|
||||||
emit progress("Starting upload...");
|
emit progress(tr("Starting upload..."));
|
||||||
setState(Uploading);
|
setState(Uploading);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -174,10 +174,13 @@ void BehaviorSettingsWidget::assignedStorageSettings(StorageSettings *storageSet
|
|||||||
|
|
||||||
void BehaviorSettingsWidget::updateConstrainTooltipsBoxTooltip() const
|
void BehaviorSettingsWidget::updateConstrainTooltipsBoxTooltip() const
|
||||||
{
|
{
|
||||||
if (d->m_ui.constrainTooltipsBox->currentIndex() == 0)
|
if (d->m_ui.constrainTooltipsBox->currentIndex() == 0) {
|
||||||
d->m_ui.constrainTooltipsBox->setToolTip(tr("Display context-sensitive help or type information on mouseover."));
|
d->m_ui.constrainTooltipsBox->setToolTip(
|
||||||
else
|
tr("Display context-sensitive help or type information on mouseover."));
|
||||||
d->m_ui.constrainTooltipsBox->setToolTip(tr("Display context-sensitive help or type information on Shift+Mouseover."));
|
} else {
|
||||||
|
d->m_ui.constrainTooltipsBox->setToolTip(
|
||||||
|
tr("Display context-sensitive help or type information on Shift+Mouseover."));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void BehaviorSettingsWidget::setAssignedBehaviorSettings(const BehaviorSettings &behaviorSettings)
|
void BehaviorSettingsWidget::setAssignedBehaviorSettings(const BehaviorSettings &behaviorSettings)
|
||||||
|
|||||||
@@ -59,36 +59,6 @@ QtSingleApplication::QtSingleApplication(const QString &appId, int &argc, char *
|
|||||||
sysInit(appId);
|
sysInit(appId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
QtSingleApplication::QtSingleApplication(int &argc, char **argv, Type type)
|
|
||||||
: QApplication(argc, argv, type)
|
|
||||||
{
|
|
||||||
sysInit();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#if defined(Q_WS_X11)
|
|
||||||
QtSingleApplication::QtSingleApplication(Display* dpy, Qt::HANDLE visual, Qt::HANDLE colormap)
|
|
||||||
: QApplication(dpy, visual, colormap)
|
|
||||||
{
|
|
||||||
sysInit();
|
|
||||||
}
|
|
||||||
|
|
||||||
QtSingleApplication::QtSingleApplication(Display *dpy, int &argc, char **argv, Qt::HANDLE visual, Qt::HANDLE cmap)
|
|
||||||
: QApplication(dpy, argc, argv, visual, cmap)
|
|
||||||
{
|
|
||||||
sysInit();
|
|
||||||
}
|
|
||||||
|
|
||||||
QtSingleApplication::QtSingleApplication(Display* dpy, const QString &appId,
|
|
||||||
int argc, char **argv, Qt::HANDLE visual, Qt::HANDLE colormap)
|
|
||||||
: QApplication(dpy, argc, argv, visual, colormap)
|
|
||||||
{
|
|
||||||
this->appId = appId;
|
|
||||||
sysInit(appId);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bool QtSingleApplication::event(QEvent *event)
|
bool QtSingleApplication::event(QEvent *event)
|
||||||
{
|
{
|
||||||
if (event->type() == QEvent::FileOpen) {
|
if (event->type() == QEvent::FileOpen) {
|
||||||
|
|||||||
@@ -40,11 +40,6 @@ class QtSingleApplication : public QApplication
|
|||||||
public:
|
public:
|
||||||
QtSingleApplication(int &argc, char **argv, bool GUIenabled = true);
|
QtSingleApplication(int &argc, char **argv, bool GUIenabled = true);
|
||||||
QtSingleApplication(const QString &id, int &argc, char **argv);
|
QtSingleApplication(const QString &id, int &argc, char **argv);
|
||||||
QtSingleApplication(int &argc, char **argv, Type type);
|
|
||||||
#if defined(Q_WS_X11)
|
|
||||||
explicit QtSingleApplication(Display *dpy, Qt::HANDLE visual = 0, Qt::HANDLE colormap = 0);
|
|
||||||
QtSingleApplication(Display *dpy, int &argc, char **argv, Qt::HANDLE visual = 0, Qt::HANDLE cmap = 0);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bool isRunning(qint64 pid = -1);
|
bool isRunning(qint64 pid = -1);
|
||||||
|
|
||||||
@@ -63,10 +58,6 @@ public Q_SLOTS:
|
|||||||
//Obsolete methods:
|
//Obsolete methods:
|
||||||
public:
|
public:
|
||||||
void initialize(bool = true);
|
void initialize(bool = true);
|
||||||
|
|
||||||
#if defined(Q_WS_X11)
|
|
||||||
QtSingleApplication(Display* dpy, const QString &id, int argc, char **argv, Qt::HANDLE visual = 0, Qt::HANDLE colormap = 0);
|
|
||||||
#endif
|
|
||||||
// end obsolete methods
|
// end obsolete methods
|
||||||
|
|
||||||
Q_SIGNALS:
|
Q_SIGNALS:
|
||||||
|
|||||||
Reference in New Issue
Block a user