KTextTemplate::Engine Class

class KTextTemplate::Engine

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

Header: #include <KTextTemplate/Engine>
CMake: find_package(KF6 REQUIRED COMPONENTS TextTemplate)
target_link_libraries(mytarget PRIVATE KF6::TextTemplate)
Inherits: QObject

Public Functions

Engine(QObject *parent = {})
void addDefaultLibrary(const QString &libName)
void addPluginPath(const QString &dir)
void addTemplateLoader(QSharedPointer<KTextTemplate::AbstractTemplateLoader> loader)
QStringList defaultLibraries() const
KTextTemplate::Template loadByName(const QString &name) const
std::pair<QString, QString> mediaUri(const QString &fileName) const
KTextTemplate::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<KTextTemplate::AbstractTemplateLoader>> templateLoaders()

Detailed Description

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();

auto loader = QSharedPointer<FileSystemTemplateLoader>::create();
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" );

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;
};

Member Function Documentation

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

Constructor

void Engine::addDefaultLibrary(const QString &libName)

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

void Engine::addPluginPath(const QString &dir)

Prepend dir to the list of plugin dirs.

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

Adds loader to the TemplateLoaders currently configured on the Engine.

QStringList Engine::defaultLibraries() const

Returns the libraries available by default to new Templates.

KTextTemplate::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.

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.

KTextTemplate::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.

QStringList Engine::pluginPaths() const

Returns the currently configured plugin dirs

See also setPluginPaths().

void Engine::removeDefaultLibrary(const QString &libName)

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

void Engine::removePluginPath(const QString &dir)

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

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 pluginPaths().

void Engine::setSmartTrimEnabled(bool enabled)

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

See also smartTrimEnabled().

bool Engine::smartTrimEnabled() const

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

This is false by default.

See also setSmartTrimEnabled().

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

Returns the TemplateLoaders currently configured on the Engine.