Commit b7e319bc authored by Venugopal Shivashankar's avatar Venugopal Shivashankar Committed by The Qt Project
Browse files

Changed the plugin module name


The earlier name, com.nokia.TimeExample is irrelevant now.
Also updated all instances of documentation where this older module
name was referred.

Change-Id: Ic252d0e72af23c2d39d5fed55f242e47c1b6bde9
Reviewed-by: default avatarJ-P Nurmi <jpnurmi@digia.com>
Reviewed-by: default avatarJens Bache-Wiig <jens.bache-wiig@digia.com>
parent 3c4574e3
dev 5.10 5.11 5.12 5.12.1 5.12.10 5.12.11 5.12.12 5.12.2 5.12.3 5.12.4 5.12.5 5.12.6 5.12.7 5.12.8 5.12.9 5.13 5.13.0 5.13.1 5.13.2 5.14 5.14.0 5.14.1 5.14.2 5.15 5.15.0 5.15.1 5.15.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 5.9.8 6.0 6.0.0 6.1 6.1.0 6.1.1 6.1.2 6.1.3 6.2 6.2.0 6.2.1 6.2.2 old/5.0 old/5.1 old/5.2 wip/cmake wip/dbus wip/gc wip/itemviews wip/nacl wip/new-backend wip/pointerhandler wip/propertycache-refactor wip/qquickdeliveryagent wip/scenegraphng wip/tizen wip/webassembly v5.15.0-alpha1 v5.14.1 v5.14.0 v5.14.0-rc2 v5.14.0-rc1 v5.14.0-beta3 v5.14.0-beta2 v5.14.0-beta1 v5.14.0-alpha1 v5.13.2 v5.13.1 v5.13.0 v5.13.0-rc3 v5.13.0-rc2 v5.13.0-rc1 v5.13.0-beta4 v5.13.0-beta3 v5.13.0-beta2 v5.13.0-beta1 v5.13.0-alpha1 v5.12.7 v5.12.6 v5.12.5 v5.12.4 v5.12.3 v5.12.2 v5.12.1 v5.12.0 v5.12.0-rc2 v5.12.0-rc1 v5.12.0-beta4 v5.12.0-beta3 v5.12.0-beta2 v5.12.0-beta1 v5.12.0-alpha1 v5.11.3 v5.11.2 v5.11.1 v5.11.0 v5.11.0-rc2 v5.11.0-rc1 v5.11.0-beta4 v5.11.0-beta3 v5.11.0-beta2 v5.11.0-beta1 v5.11.0-alpha1 v5.10.1 v5.10.0 v5.10.0-rc3 v5.10.0-rc2 v5.10.0-rc1 v5.10.0-beta4 v5.10.0-beta3 v5.10.0-beta2 v5.10.0-beta1 v5.10.0-alpha1 v5.9.9 v5.9.8 v5.9.7 v5.9.6 v5.9.5 v5.9.4 v5.9.3 v5.9.2 v5.9.1 v5.9.0 v5.9.0-rc2 v5.9.0-rc1 v5.9.0-beta4 v5.9.0-beta3 v5.9.0-beta2 v5.9.0-beta1 v5.9.0-alpha1 v5.8.0 v5.8.0-rc1 v5.8.0-beta1 v5.8.0-alpha1 v5.7.1 v5.7.0 v5.7.0-rc1 v5.7.0-beta1 v5.7.0-alpha1 v5.6.3 v5.6.2 v5.6.1 v5.6.1-1 v5.6.0 v5.6.0-rc1 v5.6.0-beta1 v5.6.0-alpha1 v5.5.1 v5.5.0 v5.5.0-rc1 v5.5.0-beta1 v5.5.0-alpha1 v5.4.2 v5.4.1 v5.4.0 v5.4.0-rc1 v5.4.0-beta1 v5.4.0-alpha1 v5.3.2 v5.3.1 v5.3.0 v5.3.0-rc1 v5.3.0-beta1 v5.3.0-alpha1 v5.2.1 v5.2.0 v5.2.0-rc1 v5.2.0-beta1 v5.2.0-alpha1 v5.1.1 v5.1.0 v5.1.0-rc2 v5.1.0-rc1 v5.1.0-beta1 v5.1.0-alpha1 v5.0.2 v5.0.1 v5.0.0 v5.0.0-rc2 v5.0.0-rc1 v5.0.0-beta2
No related merge requests found
Showing with 70 additions and 37 deletions
This example shows a module "com.nokia.TimeExample" that is implemented
by a C++ plugin (providing the "Time" type), and by QML files (providing the
"Clock" type).
To run:
make install
QML_IMPORT_PATH=$PWD qmlscene plugins.qml
examples/qml/plugins/doc/images/qml-plugins-example.png

15.4 KB

/****************************************************************************
**
** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies).
** Contact: http://www.qt-project.org/legal
**
** This file is part of the documentation of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:FDL$
** 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 Free Documentation License Usage
** Alternatively, this file may be used under the terms of the GNU Free
** Documentation License version 1.3 as published by the Free Software
** Foundation and appearing in the file included in the packaging of
** this file. Please review the following information to ensure
** the GNU Free Documentation License version 1.3 requirements
** will be met: http://www.gnu.org/copyleft/fdl.html.
** $QT_END_LICENSE$
**
****************************************************************************/
/*!
\title QML Plugin Example
\example plugins
\brief This example creates a C++ plugin extension by subclassing QQmlExtensionPlugin.
\image qml-plugins-example.png
To run this example, use the following commands on the prompt:
\code
> qmake
> make
> qmlscene -I imports plugins.qml
\endcode
*/
module com.nokia.TimeExample module TimeExample
Clock 1.0 Clock.qml Clock 1.0 Clock.qml
plugin qmlqtimeexampleplugin plugin qmlqtimeexampleplugin
...@@ -146,7 +146,7 @@ class QExampleQmlPlugin : public QQmlExtensionPlugin ...@@ -146,7 +146,7 @@ class QExampleQmlPlugin : public QQmlExtensionPlugin
public: public:
void registerTypes(const char *uri) void registerTypes(const char *uri)
{ {
Q_ASSERT(uri == QLatin1String("com.nokia.TimeExample")); Q_ASSERT(uri == QLatin1String("TimeExample"));
qmlRegisterType<TimeModel>(uri, 1, 0, "Time"); qmlRegisterType<TimeModel>(uri, 1, 0, "Time");
} }
}; };
......
...@@ -2,24 +2,24 @@ TEMPLATE = lib ...@@ -2,24 +2,24 @@ TEMPLATE = lib
CONFIG += qt plugin CONFIG += qt plugin
QT += qml QT += qml
DESTDIR = com/nokia/TimeExample DESTDIR = imports/TimeExample
TARGET = qmlqtimeexampleplugin TARGET = qmlqtimeexampleplugin
SOURCES += plugin.cpp SOURCES += plugin.cpp
qdeclarativesources.files += \ qdeclarativesources.files += \
com/nokia/TimeExample/qmldir \ imports/TimeExample/qmldir \
com/nokia/TimeExample/center.png \ imports/TimeExample/center.png \
com/nokia/TimeExample/clock.png \ imports/TimeExample/clock.png \
com/nokia/TimeExample/Clock.qml \ imports/TimeExample/Clock.qml \
com/nokia/TimeExample/hour.png \ imports/TimeExample/hour.png \
com/nokia/TimeExample/minute.png imports/TimeExample/minute.png
qdeclarativesources.path += $$[QT_INSTALL_EXAMPLES]/qtdeclarative/qml/plugins/com/nokia/TimeExample qdeclarativesources.path += $$[QT_INSTALL_EXAMPLES]/qtdeclarative/qml/plugins/imports/TimeExample
sources.files += plugins.pro plugin.cpp plugins.qml README sources.files += plugins.pro plugin.cpp plugins.qml
sources.path += $$[QT_INSTALL_EXAMPLES]/qtdeclarative/qml/plugins sources.path += $$[QT_INSTALL_EXAMPLES]/qtdeclarative/qml/plugins
target.path += $$[QT_INSTALL_EXAMPLES]/qtdeclarative/qml/plugins/com/nokia/TimeExample target.path += $$[QT_INSTALL_EXAMPLES]/qtdeclarative/qml/plugins/imports/TimeExample
INSTALLS += qdeclarativesources sources target INSTALLS += qdeclarativesources sources target
...@@ -38,9 +38,9 @@ ...@@ -38,9 +38,9 @@
** **
****************************************************************************/ ****************************************************************************/
//![0] //![0]
import com.nokia.TimeExample 1.0 // import types from the plugin import TimeExample 1.0 // import types from the plugin
Clock { // this class is defined in QML (com/nokia/TimeExample/Clock.qml) Clock { // this class is defined in QML (imports/TimeExample/Clock.qml)
Time { // this class is defined in C++ (plugin.cpp) Time { // this class is defined in C++ (plugin.cpp)
id: time id: time
......
...@@ -39,7 +39,7 @@ ...@@ -39,7 +39,7 @@
****************************************************************************/ ****************************************************************************/
//! [import] //! [import]
import com.nokia.TimeExample 1.0 import TimeExample 1.0
//! [import] //! [import]
Item { Item {
......
...@@ -87,12 +87,12 @@ ...@@ -87,12 +87,12 @@
types into the runtime. types into the runtime.
For this example, the TimeExample source directory is in For this example, the TimeExample source directory is in
\c{com/nokia/TimeExample}. The plugin's type namespace will mirror \c{imports/TimeExample}. The plugin's type namespace will mirror
this structure, so the types are registered into the namespace this structure, so the types are registered into the namespace
"com.nokia.TimeExample". "TimeExample".
Additionally, the project file, in a \c .pro file, defines the project as a plugin library, Additionally, the project file, in a \c .pro file, defines the project as a plugin library,
specifies it should be built into the \c com/nokia/TimeExample directory, and registers specifies it should be built into the \c imports/TimeExample directory, and registers
the plugin target name and various other details: the plugin target name and various other details:
\code \code
...@@ -100,21 +100,21 @@ ...@@ -100,21 +100,21 @@
CONFIG += qt plugin CONFIG += qt plugin
QT += qml QT += qml
DESTDIR = com/nokia/TimeExample DESTDIR = imports/TimeExample
TARGET = qmlqtimeexampleplugin TARGET = qmlqtimeexampleplugin
SOURCES += qexampleqmlplugin.cpp SOURCES += qexampleqmlplugin.cpp
\endcode \endcode
Finally, a \l{Module Definition qmldir Files}{qmldir file} is required Finally, a \l{Module Definition qmldir Files}{qmldir file} is required
in the \c com/nokia/TimeExample directory to describe the plugin and the types that it in the \c imports/TimeExample directory to describe the plugin and the types that it
exports. The plugin includes a \c Clock.qml file along with the \c qmlqtimeexampleplugin exports. The plugin includes a \c Clock.qml file along with the \c qmlqtimeexampleplugin
that is built by the project (as shown above in the \c .pro file) so both of these that is built by the project (as shown above in the \c .pro file) so both of these
need to be specified in the \c qmldir file: need to be specified in the \c qmldir file:
\quotefile examples/qml/plugins/com/nokia/TimeExample/qmldir \quotefile examples/qml/plugins/imports/TimeExample/qmldir
Once the project is built and installed, the new \c Time component is Once the project is built and installed, the new \c Time component is
accessible by any QML component that imports the \c com.nokia.TimeExample accessible by any QML component that imports the \c TimeExample
module module
\snippet examples/qml/plugins/plugins.qml 0 \snippet examples/qml/plugins/plugins.qml 0
......
...@@ -81,7 +81,7 @@ QT_BEGIN_NAMESPACE ...@@ -81,7 +81,7 @@ QT_BEGIN_NAMESPACE
To make this class available as a QML type, create a plugin that registers To make this class available as a QML type, create a plugin that registers
this type with a specific \l {QML Modules}{module} using qmlRegisterType(). For this example the plugin this type with a specific \l {QML Modules}{module} using qmlRegisterType(). For this example the plugin
module will be named \c com.nokia.TimeExample (as defined in the project module will be named \c TimeExample (as defined in the project
file further below). file further below).
\snippet examples/qml/plugins/plugin.cpp plugin \snippet examples/qml/plugins/plugin.cpp plugin
...@@ -93,27 +93,27 @@ QT_BEGIN_NAMESPACE ...@@ -93,27 +93,27 @@ QT_BEGIN_NAMESPACE
ensures the module is imported correctly by any QML components that use this plugin. ensures the module is imported correctly by any QML components that use this plugin.
The project file defines the project as a plugin library and specifies The project file defines the project as a plugin library and specifies
it should be built into the \c com/nokia/TimeExample directory: it should be built into the \c imports/TimeExample directory:
\code \code
TEMPLATE = lib TEMPLATE = lib
CONFIG += qt plugin CONFIG += qt plugin
QT += qml QT += qml
DESTDIR = com/nokia/TimeExample DESTDIR = imports/TimeExample
TARGET = qmlqtimeexampleplugin TARGET = qmlqtimeexampleplugin
... ...
\endcode \endcode
Finally, a \l{Module Definition qmldir Files}{qmldir file} is required in the \c com/nokia/TimeExample directory Finally, a \l{Module Definition qmldir Files}{qmldir file} is required in the \c imports/TimeExample directory
that describes the plugin. This directory includes a \c Clock.qml file that that describes the plugin. This directory includes a \c Clock.qml file that
should be bundled with the plugin, so it needs to be specified in the \c qmldir should be bundled with the plugin, so it needs to be specified in the \c qmldir
file: file:
\quotefile examples/qml/plugins/com/nokia/TimeExample/qmldir \quotefile examples/qml/plugins/imports/TimeExample/qmldir
Once the project is built and installed, the new \c Time element can be Once the project is built and installed, the new \c Time element can be
used by any QML component that imports the \c com.nokia.TimeExample module: used by any QML component that imports the \c TimeExample module:
\snippet examples/qml/plugins/plugins.qml 0 \snippet examples/qml/plugins/plugins.qml 0
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment