TemplateParser::TemplateParserJob

Search for usage in LXR

TemplateParser::TemplateParserJob Class Reference

#include <templateparserjob.h>

Inheritance diagram for TemplateParser::TemplateParserJob:

Public Types

enum  AllowSelection : uint8_t { SelectionAllowed , NoSelectionAllowed }
 
enum  Mode : uint8_t { NewMessage , Reply , ReplyAll , Forward }
 
enum  Quotes : uint8_t { ReplyAsOriginalMessage , ReplyAsPlain , ReplyAsHtml }
 
- Public Types inherited from QObject
typedef  QObjectList
 

Signals

void parsingDone (bool cursorPositionWasSet)
 
void parsingFailed ()
 

Public Member Functions

 TemplateParserJob (const KMime::Message::Ptr &amsg, const Mode amode, QObject *parent=nullptr)
 
void process (const KMime::Message::Ptr &aorig_msg, qint64 afolder=-1)
 
void process (const QString &tmplName, const KMime::Message::Ptr &aorig_msg, qint64 afolder=-1)
 
void processWithIdentity (uint uoid, const KMime::Message::Ptr &aorig_msg, qint64 afolder=-1)
 
void processWithTemplate (const QString &tmpl)
 
void setAllowDecryption (const bool allowDecryption)
 
void setIdentityManager (KIdentityManagementCore::IdentityManager *ident)
 
void setReplyAsHtml (bool replyAsHtml)
 
void setSelection (const QString &selection)
 
void setWordWrap (bool wrap, int wrapColWidth=80)
 
- 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

- 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

The TemplateParser transforms a message with a given template.

Introduction
The TemplateParser transforms a message with a given template. A template contains text and commands, such as QUOTE or ODATE, which will be replaced with the real values in process().
Basics
The message given in the templateparser constructor amsg, is the message that is being transformed. aorig_msg is the original message to which actions are performed. The message text in amsg will be replaced by the processed text of the template, but other properties, such as the attachments or the subject, are preserved.

There are two different kind of commands: Those that work on the message that is to be transformed and those that work on an 'original message'. Those that work on the message that is to be transformed have no special prefix, e.g. 'DATE'. Those that work on the original message have an 'O' prefix, for example 'ODATE'. This means that the DATE command will take the date of the message passed in the constructor, the message which is to be transformed, whereas the ODATE command will take the date of the message that is being passed in process(), the original message.

The process()
The process() function takes aorig_msg as parameter. This aorig_msg is the original message from which various commands in templates with prefix 'O' extract the data and adds to the processed message. This function finds the template and passes them to processWithTemplate(), where templates are processed and its value is added to the processed message.
Reply To/Forward Plain Text Mails
Plain Text mails are the mails with only text part and no html part. While creating reply/forward to mails, processWithTemplate() processes all the commands and then appends its values to plainBody and htmlBody. This function then on the basis of whether the user wants to use plain mails or HTML mails, clears the htmlBody, or just passes both the plainBody and htmlBody unaltered.
Reply To/Forward HTML Mails
By HTML mails here, we mean multipart/alternative mails. As mentioned above, all commands in the TemplateParser appends text, i.e. plain text to plainBody and html text to htmlBody in the function processWithTemplate(). This function also takes a decision of clearing the htmlBody on the basis of fact whether the user wants to reply/forward using plain mails or multipart/alternative mails.
When "TO" and when "NOT TO" make multipart/alternative Mails
User is the master to decide when to and when not to make multipart/alternative mails. For user who don't prefer using HTML mails There is a TemplateParserSettings::self()->replyUsingHtml() (in GUI as Settings->Configure KMail-> Composer->General->"Reply using HTML if present"), which when not true (checkbox disabled in UI), will clear the htmlBody. An another option within the standard templates, FORCEDPLAIN command raises the flag, ReplyAsPlain. This flag when raised in processWithTemplate() takes care that the processed message will contain text/plain part by clearing the htmlBody.

Once the htmlBody is cleared, plainBody and an empty htmlBody is passed to addProcessedBodyToMessage(). Here since the htmlBody is empty, text/plain messages are assembled and thus user is not dealing with any kind of HTML part.

For user who do prefer using HTML mails The setting discussed above as "Reply using HTML if present" (when checked to true), passes the htmlBody to addProcessedBodyToMessage() without doing any changes. An another option FORCEDHTML within standard templates command raises the flag ReplyAsHtml. This flag when raised in processWithTemplate() takes care that the htmlBody is passed to addProcessedBodyToMessage() unaltered.

Since htmlBody received by addProcessedBodyToMessage() is not empty, multipart/alternative messages are assembled.

@NOTE Resolving conflict between TemplateParserSettings "replyUsingHtml" and FORCEDXXXX command. The conflict is resolved by simply giving preference to the commands over TemplateParserSettings.

Make plain part
mMsg is the reply message in which the message text will be replaced by the processed value from templates.

In case of no attachments, the message will be a single-part message. A KMime::Content containing the plainBody from processWithTemplate() is created. Then the encodedBody(), contentType (text/plain) of this KMime::Content is set in the body and the header of mMsg.

Make multipart/alternative mails
First of all a KMime::Content (content) is created with a content-type of multipart/alternative. Then in the same way as plain-part is created in above paragraph, a KMime::Content (sub-content) containing the plainBody is created and added as child to the content. Then a new KMime::Content (sub-content) with htmlBody as the body is created. The content-type is set as text/html. This new sub-content is then added to the parent content. Now, since the parent content (multipart/alternative) has two sub-content (text/plain and text/html) to it, it is added to the reply message (mMsg).

TODO: What is the usecase of the commands that work on the message to be transformed? In general you only use the commands that work on the original message...

Definition at line 128 of file templateparserjob.h.

Member Enumeration Documentation

◆ AllowSelection

enum TemplateParser::TemplateParserJob::AllowSelection : uint8_t

Definition at line 141 of file templateparserjob.h.

◆ Mode

enum TemplateParser::TemplateParserJob::Mode : uint8_t

Definition at line 134 of file templateparserjob.h.

◆ Quotes

enum TemplateParser::TemplateParserJob::Quotes : uint8_t

Definition at line 146 of file templateparserjob.h.

Constructor & Destructor Documentation

◆ TemplateParserJob()

TemplateParserJob::TemplateParserJob ( const KMime::Message::Ptr & amsg,
const Mode amode,
QObject * parent = nullptr )
explicit

Definition at line 73 of file templateparserjob.cpp.

Member Function Documentation

◆ process() [1/2]

void TemplateParserJob::process ( const KMime::Message::Ptr & aorig_msg,
qint64 afolder = -1 )

Definition at line 140 of file templateparserjob.cpp.

◆ process() [2/2]

void TemplateParserJob::process ( const QString & tmplName,
const KMime::Message::Ptr & aorig_msg,
qint64 afolder = -1 )

Definition at line 160 of file templateparserjob.cpp.

◆ processWithIdentity()

void TemplateParserJob::processWithIdentity ( uint uoid,
const KMime::Message::Ptr & aorig_msg,
qint64 afolder = -1 )

Definition at line 169 of file templateparserjob.cpp.

◆ processWithTemplate()

void TemplateParserJob::processWithTemplate ( const QString & tmpl)

Definition at line 204 of file templateparserjob.cpp.

◆ setAllowDecryption()

void TemplateParserJob::setAllowDecryption ( const bool allowDecryption)

Sets whether the template parser is allowed to decrypt the original message when needing its message text, for example for the QUOTE command.

If true, it will tell the ObjectTreeParser it uses internally to decrypt the message, and that will possibly show a password request dialog to the user.

The default is false.

Definition at line 86 of file templateparserjob.cpp.

◆ setIdentityManager()

void TemplateParserJob::setIdentityManager ( KIdentityManagementCore::IdentityManager * ident)

Set the identity manager to be used when creating the template.

Definition at line 97 of file templateparserjob.cpp.

◆ setReplyAsHtml()

void TemplateParserJob::setReplyAsHtml ( bool replyAsHtml)

Definition at line 239 of file templateparserjob.cpp.

◆ setSelection()

void TemplateParserJob::setSelection ( const QString & selection)

Sets the selection.

If this is set, only the selection will be added to commands such as QUOTE. Otherwise, the whole message is quoted. If this is not called at all, the whole message is quoted as well. Call this before calling process().

Definition at line 81 of file templateparserjob.cpp.

◆ setWordWrap()

void TemplateParserJob::setWordWrap ( bool wrap,
int wrapColWidth = 80 )

Tell template parser whether or not to wrap words, and at what column to wrap at.

Default is true, wrapping at 80chars.

Definition at line 1368 of file templateparserjob.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:55:29 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.