Akonadi::Server::PreprocessorManager
#include <preprocessormanager.h>
Public Member Functions | |
PreprocessorManager (Tracer &tracer) | |
~PreprocessorManager () override | |
void | beginHandleItem (const PimItem &item, const DataStore *dataStore) |
bool | isActive () |
bool | isEnabled () const |
void | registerInstance (const QString &id) |
void | setEnabled (bool enabled) |
void | unregisterInstance (const QString &id) |
Public Member Functions inherited from QObject | |
QObject (QObject *parent) | |
QBindable< QString > | bindableObjectName () |
bool | blockSignals (bool block) |
const QObjectList & | children () 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< QByteArray > | dynamicPropertyNames () const const |
virtual bool | event (QEvent *e) |
virtual bool | eventFilter (QObject *watched, QEvent *event) |
T | 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 QMetaObject * | metaObject () const const |
void | moveToThread (QThread *targetThread) |
QString | objectName () const const |
void | objectNameChanged (const QString &objectName) |
QObject * | parent () 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 | |
T | qobject_cast (const QObject *object) |
T | 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) |
QThread * | thread () const const |
Protected Member Functions | |
void | preProcessorFinishedHandlingItem (PreprocessorInstance *preProcessor, qint64 itemId) |
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 |
QObject * | sender () const const |
int | senderSignalIndex () const const |
virtual void | timerEvent (QTimerEvent *event) |
Protected Attributes | |
bool | mEnabled = false |
QTimer * | mHeartbeatTimer = nullptr |
QMutex | mMutex |
QList< PreprocessorInstance * > | mPreprocessorChain |
Tracer & | mTracer |
QHash< const DataStore *, std::deque< qint64 > * > | mTransactionWaitQueueHash |
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) |
Detailed Description
The manager for preprocessor agents.
This class takes care of synchronizing the preprocessor agents.
The preprocessors see the incoming PimItem objects before the user can see them (as long as the UI applications honor the hidden attribute). The items are marked as hidden (by the Append and AkAppend handlers) and then enqueued to the preprocessor chain via this class. Once all the preprocessors have done their work the item is unhidden again.
Preprocessing isn't designed for critical tasks. There may be circumstances under that the Akonadi server fails to push an item to all the preprocessors. Most notably after a server restart all the items for that preprocessing was interrupted are just unhidden without any attempt to resume the preprocessor jobs.
The enqueue requests may or may not arrive from "inside" a database transaction. The uncommitted transaction would "hide" the newly created items from the preprocessor instances (which are separate processes). This class, then, takes care of holding the newly arrived items in a wait queue until their transaction is committed (or rolled back).
Definition at line 57 of file preprocessormanager.h.
Constructor & Destructor Documentation
◆ PreprocessorManager()
|
explicit |
Creates an instance of PreprocessorManager.
Definition at line 45 of file preprocessormanager.cpp.
◆ ~PreprocessorManager()
|
override |
Destroys the instance of PreprocessorManager and frees all the relevant resources.
Definition at line 61 of file preprocessormanager.cpp.
Member Function Documentation
◆ beginHandleItem()
void PreprocessorManager::beginHandleItem | ( | const PimItem & | item, |
const DataStore * | dataStore ) |
Trigger the preprocessor chain for the specified item.
The item should have been added to the Akonadi database via the specified DataStore object. If the DataStore is in a transaction then this class will put the item in a wait queue until the transaction is committed. If the transaction is rolled back the whole wait queue will be discarded. If the DataStore is not in a transaction then the item will be pushed directly to the preprocessing chain.
You should make sure that the preprocessor chain isActive() before calling this method. The items you pass to this method, also, should have the hidden attribute set.
This function is thread-safe.
Definition at line 165 of file preprocessormanager.cpp.
◆ isActive()
bool PreprocessorManager::isActive | ( | ) |
Returns true if preprocessing is active in this Akonadi server.
This means that we have at least one active preprocessor and preprocessing hasn't been explicitly disabled via configuration (so if isActive() returns true then also isEnabled() will return true).
This function is thread-safe.
Definition at line 73 of file preprocessormanager.cpp.
◆ isEnabled()
|
inline |
Returns true if this preprocessor hasn't been explicitly disabled via setEnabled( false ).
This is used to disable preprocessing via configuration even if we have a valid chain of preprocessors.
Please note that this flag doesn't tell if we actually have some registered preprocessors and thus we can do some meaningful job. You should use isActive() for this purpose.
Definition at line 131 of file preprocessormanager.h.
◆ preProcessorFinishedHandlingItem()
|
protected |
This is called by PreprocessorInstance to signal that a certain preprocessor has finished handling an item.
This function is thread-safe.
Definition at line 324 of file preprocessormanager.cpp.
◆ registerInstance()
void PreprocessorManager::registerInstance | ( | const QString & | id | ) |
This is called via D-Bus from AgentManager to register a preprocessor instance.
This function is thread-safe.
Definition at line 94 of file preprocessormanager.cpp.
◆ setEnabled()
|
inline |
Explicitly enables or disables the preprocessing in this Akonadi server.
The PreprocessorManager starts in enabled state but can be disabled at a later stage: this is mainly used to disable preprocessing via configuration.
Please note that setting this to true doesn't interrupt the currently running preprocessing jobs. Anything that was enqueued will be processed anyway. However, in Akonadi this is only invoked very early, when no preprocessors are alive yet.
Definition at line 147 of file preprocessormanager.h.
◆ unregisterInstance()
void PreprocessorManager::unregisterInstance | ( | const QString & | id | ) |
This is called via D-Bus from AgentManager to unregister a preprocessor instance.
This function is thread-safe.
Definition at line 121 of file preprocessormanager.cpp.
Member Data Documentation
◆ mEnabled
|
protected |
Is preprocessing enabled at all in this Akonadi server instance? This is true by default and can be set via setEnabled().
Mainly used to disable preprocessing via configuration file.
Definition at line 85 of file preprocessormanager.h.
◆ mHeartbeatTimer
|
protected |
The heartbeat timer.
Used mainly to expire preprocessor jobs.
Definition at line 96 of file preprocessormanager.h.
◆ mMutex
|
protected |
The mutex used to protect the internals of this class (mainly the mPreprocessorChain member).
Definition at line 91 of file preprocessormanager.h.
◆ mPreprocessorChain
|
protected |
The preprocessor chain.
The pointers inside the list are owned.
In all the algorithms we assume that this list is actually very short (say 3-4 elements) and reverse lookup (pointer->index) is really fast.
Definition at line 78 of file preprocessormanager.h.
◆ mTracer
|
protected |
Definition at line 98 of file preprocessormanager.h.
◆ mTransactionWaitQueueHash
|
protected |
The hashtable of transaction wait queues.
There is one wait queue for each DataStore that is currently in a transaction.
Definition at line 69 of file preprocessormanager.h.
The documentation for this class was generated from the following files:
Documentation copyright © 1996-2025 The KDE developers.
Generated on Fri Jan 3 2025 11:58:21 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006
KDE's Doxygen guidelines are available online.