KTextTemplate::Engine

Search for usage in LXR

KTextTemplate::Engine Class Reference

#include <KTextTemplate/Engine>

Inheritance diagram for KTextTemplate::Engine:

Public Member Functions

 Engine (QObject *parent={})
 
 ~Engine () override
 
void addDefaultLibrary (const QString &libName)
 
void addPluginPath (const QString &dir)
 
void addTemplateLoader (QSharedPointer< AbstractTemplateLoader > loader)
 
QStringList defaultLibraries () const
 
Template loadByName (const QString &name) const
 
std::pair< QString, QStringmediaUri (const QString &fileName) const
 
Template newTemplate (const QString &content, const QString &name) const
 
QStringList pluginPaths () const
 
void removeDefaultLibrary (const QString &libName)
 
void removePluginPath (const QString &dir)
 
void setPluginPaths (const QStringList &dirs)
 
void setSmartTrimEnabled (bool enabled)
 
bool smartTrimEnabled () const
 
QList< QSharedPointer< AbstractTemplateLoader > > templateLoaders ()
 
- Public Member Functions inherited from QObject
 QObject (QObject *parent)
 
QBindable< QStringbindableObjectName ()
 
bool blockSignals (bool block)
 
const QObjectListchildren () const const
 
QMetaObject::Connection connect (const QObject *sender, const char *signal, const char *method, Qt::ConnectionType type) const const
 
void deleteLater ()
 
void destroyed (QObject *obj)
 
bool disconnect (const char *signal, const QObject *receiver, const char *method) const const
 
bool disconnect (const QObject *receiver, const char *method) const const
 
void dumpObjectInfo () const const
 
void dumpObjectTree () const const
 
QList< QByteArraydynamicPropertyNames () const const
 
virtual bool event (QEvent *e)
 
virtual bool eventFilter (QObject *watched, QEvent *event)
 
findChild (const QString &name, Qt::FindChildOptions options) const const
 
QList< T > findChildren (const QRegularExpression &re, Qt::FindChildOptions options) const const
 
QList< T > findChildren (const QString &name, Qt::FindChildOptions options) const const
 
QList< T > findChildren (Qt::FindChildOptions options) const const
 
bool inherits (const char *className) const const
 
void installEventFilter (QObject *filterObj)
 
bool isQuickItemType () const const
 
bool isWidgetType () const const
 
bool isWindowType () const const
 
void killTimer (int id)
 
virtual const QMetaObjectmetaObject () const const
 
void moveToThread (QThread *targetThread)
 
QString objectName () const const
 
void objectNameChanged (const QString &objectName)
 
QObjectparent () const const
 
QVariant property (const char *name) const const
 
 Q_CLASSINFO (Name, Value)
 
 Q_EMIT Q_EMIT
 
 Q_ENUM (...)
 
 Q_ENUM_NS (...)
 
 Q_ENUMS (...)
 
 Q_FLAG (...)
 
 Q_FLAG_NS (...)
 
 Q_FLAGS (...)
 
 Q_GADGET Q_GADGET
 
 Q_GADGET_EXPORT (EXPORT_MACRO)
 
 Q_INTERFACES (...)
 
 Q_INVOKABLE Q_INVOKABLE
 
 Q_MOC_INCLUDE Q_MOC_INCLUDE
 
 Q_NAMESPACE Q_NAMESPACE
 
 Q_NAMESPACE_EXPORT (EXPORT_MACRO)
 
 Q_OBJECT Q_OBJECT
 
 Q_PROPERTY (...)
 
 Q_REVISION Q_REVISION
 
 Q_SET_OBJECT_NAME (Object)
 
 Q_SIGNAL Q_SIGNAL
 
 Q_SIGNALS Q_SIGNALS
 
 Q_SLOT Q_SLOT
 
 Q_SLOTS Q_SLOTS
 
qobject_cast (const QObject *object)
 
qobject_cast (QObject *object)
 
 QT_NO_NARROWING_CONVERSIONS_IN_CONNECT QT_NO_NARROWING_CONVERSIONS_IN_CONNECT
 
void removeEventFilter (QObject *obj)
 
void setObjectName (const QString &name)
 
void setObjectName (QAnyStringView name)
 
void setParent (QObject *parent)
 
bool setProperty (const char *name, const QVariant &value)
 
bool setProperty (const char *name, QVariant &&value)
 
bool signalsBlocked () const const
 
int startTimer (int interval, Qt::TimerType timerType)
 
int startTimer (std::chrono::milliseconds interval, Qt::TimerType timerType)
 
QThreadthread () const const
 

Additional Inherited Members

- Public Types inherited from QObject
typedef  QObjectList
 
- Properties inherited from QObject
 objectName
 
- Static Public Member Functions inherited from QObject
QMetaObject::Connection connect (const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type)
 
QMetaObject::Connection connect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method, Qt::ConnectionType type)
 
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, const QObject *context, Functor functor, Qt::ConnectionType type)
 
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method, Qt::ConnectionType type)
 
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, Functor functor)
 
bool disconnect (const QMetaObject::Connection &connection)
 
bool disconnect (const QObject *sender, const char *signal, const QObject *receiver, const char *method)
 
bool disconnect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method)
 
bool disconnect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method)
 
QString tr (const char *sourceText, const char *disambiguation, int n)
 
- Protected Member Functions inherited from QObject
virtual void childEvent (QChildEvent *event)
 
virtual void connectNotify (const QMetaMethod &signal)
 
virtual void customEvent (QEvent *event)
 
virtual void disconnectNotify (const QMetaMethod &signal)
 
bool isSignalConnected (const QMetaMethod &signal) const const
 
int receivers (const char *signal) const const
 
QObjectsender () const const
 
int senderSignalIndex () const const
 
virtual void timerEvent (QTimerEvent *event)
 

Detailed Description

KTextTemplate::Engine is the main entry point for creating KTextTemplate Templates.

The KTextTemplate::Engine is responsible for configuring and creating Template objects. In typical use, one or more AbstractTemplateLoader objects will be added to the Engine to load template objects, and plugin directories will be set to enable finding template tags and filters.

auto engine = new Engine();
loader->setTemplateDirs( {"/usr/share/myapp/templates"} );
engine->addTemplateLoader( loader );
engine->addPluginPath( "/usr/lib/myapp" );
auto template1 = engine->newTemplate( "Template content", "template name" );
auto template2 = engine->loadByName( "templatefile.html" );
Engine(QObject *parent={})
Constructor.
Definition engine.cpp:29
QSharedPointer< T > create(Args &&... args)

Once it is configured, the Engine can be used to create new templates by name by loading the templates with the loadByName method, or by defining the content in the newTemplate method.

By default the builtin tags and filters distributed with KTextTemplate are available in all templates without using the {% load %} tag in the template. These pre-loaded libraries may be configured if appropriate to the application. For example, an application which defines its own tags and filters may want them to be always available, or it may be desirable to restrict the features available to template authors by removing built in libraries.

Different Engine objects can be used to create templates with differing configurations.

Insignificant whitespace

The output of rendering a template depends on the content of the template. In some cases when generating content in which whitespace is significant, this can have undesired effects. For example, given a template to generate C++ code like:

  class MyClass {
  {# This loop creates the  #}
  {# methods in the class   #}
  {% for method in methods %}
    {% if method.hasDox %}
      {{ method.dox }}
    {% endif %}
      {{ method.signature }}
  {% endfor %}
  };

The output would have a lot of whitespace which is not necessarily wanted.

class MyClass {
void foo() const;
};

It is possible to strip insignificant whitespace by enabling the smartTrim feature with setSmartTrimEnabled. When enabled the output will not contain a newline for any line in the template which has only one token of template syntax, such as a comment, tag or variable.

class MyClass {
void foo() const;
};
Author
Stephen Kelly steve.nosp@m.ire@.nosp@m.gmail.nosp@m..com

Definition at line 109 of file engine.h.

Constructor & Destructor Documentation

◆ Engine()

Engine::Engine ( QObject * parent = {})

Constructor.

Definition at line 29 of file engine.cpp.

◆ ~Engine()

Engine::~Engine ( )
override

Destructor.

Definition at line 40 of file engine.cpp.

Member Function Documentation

◆ addDefaultLibrary()

void Engine::addDefaultLibrary ( const QString & libName)

Adds the library named libName to the libraries available by default to new Templates.

Definition at line 107 of file engine.cpp.

◆ addPluginPath()

void Engine::addPluginPath ( const QString & dir)

Prepend dir to the list of plugin dirs.

Definition at line 80 of file engine.cpp.

◆ addTemplateLoader()

void Engine::addTemplateLoader ( QSharedPointer< AbstractTemplateLoader > loader)

Adds loader to the TemplateLoaders currently configured on the Engine.

Definition at line 55 of file engine.cpp.

◆ defaultLibraries()

QStringList Engine::defaultLibraries ( ) const

Returns the libraries available by default to new Templates.

Definition at line 101 of file engine.cpp.

◆ loadByName()

Template Engine::loadByName ( const QString & name) const

Load the Template identified by name.

The Templates and plugins loaded will be determined by the Engine configuration.

Definition at line 311 of file engine.cpp.

◆ mediaUri()

std::pair< QString, QString > Engine::mediaUri ( const QString & fileName) const

Returns a URI for a media item with the name name.

Typically this will be used for images. For example the media URI for the image "header_logo.png" may be "/home/user/common/header_logo.png" or "/home/user/some_theme/header_logo.png" depending on the templateLoaders configured.

This method will not usually be called by application code. To load media in a template, use the {% media_finder %} template tag.

Definition at line 61 of file engine.cpp.

◆ newTemplate()

Template Engine::newTemplate ( const QString & content,
const QString & name ) const

Create a new Template with the content content identified by name.

The secondary Templates and plugins loaded will be determined by the Engine configuration.

Definition at line 332 of file engine.cpp.

◆ pluginPaths()

QStringList Engine::pluginPaths ( ) const

Returns the currently configured plugin dirs.

Definition at line 95 of file engine.cpp.

◆ removeDefaultLibrary()

void Engine::removeDefaultLibrary ( const QString & libName)

Removes the library named libName from the libraries available by default to new Templates.

Definition at line 113 of file engine.cpp.

◆ removePluginPath()

void Engine::removePluginPath ( const QString & dir)

Removes all instances of dir from the list of plugin dirs.

Definition at line 89 of file engine.cpp.

◆ setPluginPaths()

void Engine::setPluginPaths ( const QStringList & dirs)

Sets the plugin dirs currently configured on the Engine to dirs.

Warning
This overwrites the default paths. You normally want addPluginPath.
See also
Finding tags and filters

Definition at line 74 of file engine.cpp.

◆ setSmartTrimEnabled()

void Engine::setSmartTrimEnabled ( bool enabled)

Sets whether the smart trim feature is enabled for newly loaded templates.

See also
smart_trim

Definition at line 341 of file engine.cpp.

◆ smartTrimEnabled()

bool Engine::smartTrimEnabled ( ) const

Returns whether the smart trim feature is enabled for newly loaded templates.

See also
smart_trim

This is false by default.

Definition at line 347 of file engine.cpp.

◆ templateLoaders()

QList< QSharedPointer< AbstractTemplateLoader > > Engine::templateLoaders ( )

Returns the TemplateLoaders currently configured on the Engine.

Definition at line 49 of file engine.cpp.


The documentation for this class was generated from the following files:
This file is part of the KDE documentation.
Documentation copyright © 1996-2025 The KDE developers.
Generated on Fri Jan 3 2025 11:58:58 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.