cutelyst 3.9.1
A C++ Web Framework built on top of Qt, using the simple approach of Catalyst (Perl) framework.
Cutelyst::ActionChain Class Reference

Holds a chain of Cutelyst Actions. More...

#include <Cutelyst/ActionChain>

Inheritance diagram for Cutelyst::ActionChain:

Public Member Functions

 ActionChain (const ActionList &chain, QObject *parent=nullptr)
ActionList chain () const noexcept
virtual qint8 numberOfCaptures () const noexcept override
Public Member Functions inherited from Cutelyst::Action
 Action (QObject *parent=nullptr)
QString attribute (const QString &name, const QString &defaultValue={}) const
ParamsMultiMap attributes () const noexcept
QString className () const
Controllercontroller () const
bool dispatch (Context *c)
virtual bool match (int numberOfArgs) const noexcept
virtual bool matchCaptures (int numberOfCaptures) const noexcept
virtual Modifiers modifiers () const override
QString ns () const noexcept
virtual qint8 numberOfArgs () const noexcept
void setAttributes (const ParamsMultiMap &attributes)
Public Member Functions inherited from Cutelyst::Component
 Component (QObject *parent=nullptr)
bool execute (Context *c)
virtual bool init (Application *application, const QVariantHash &args)
QString name () const
QString reverse () const
void setName (const QString &name)
void setReverse (const QString &reverse)

Protected Member Functions

virtual bool doExecute (Context *c) override
Protected Member Functions inherited from Cutelyst::Action
 Action (ActionPrivate *ptr, QObject *parent=nullptr)
 A derived class using pimpl should call this constructor, to reduce the number of memory allocations.
void setController (Controller *controller)
void setMethod (const QMetaMethod &method)
void setupAction (const QVariantHash &args, Application *app)
Protected Member Functions inherited from Cutelyst::Component
 Component (ComponentPrivate *d, QObject *parent=nullptr)
 A derived class using pimpl should call this constructor, to reduce the number of memory allocations.
virtual bool afterExecute (Context *c)
void applyRoles (const QStack< Component * > &roles)
virtual bool aroundExecute (Context *c, QStack< Component * > stack)
virtual bool beforeExecute (Context *c)
virtual bool dispatcherReady (const Dispatcher *dispatch, Controller *controller)

Additional Inherited Members

Public Types inherited from Cutelyst::Component
enum  Modifier {
  None , OnlyExecute , BeforeExecute , AroundExecute ,
  AfterExecute
}

Detailed Description

This class represents a chain of Cutelyst Actions. It behaves exactly like the action at the end of the chain except on dispatch it will execute all the actions in the chain in order.

Definition at line 23 of file actionchain.h.

Constructor & Destructor Documentation

◆ ActionChain()

ActionChain::ActionChain ( const ActionList & chain,
QObject * parent = nullptr )
explicit

Member Function Documentation

◆ chain()

ActionList ActionChain::chain ( ) const
noexcept

The action chain

Returns
a list of Cutelyst::Action objects encapsulated by this chain.

Definition at line 36 of file actionchain.cpp.

References ActionChain().

Referenced by ActionChain(), and doExecute().

◆ doExecute()

bool ActionChain::doExecute ( Context * c)
overrideprotectedvirtual

◆ numberOfCaptures()

qint8 ActionChain::numberOfCaptures ( ) const
overridevirtualnoexcept

Reimplemented from Action::numberOfCaptures()

Reimplemented from Cutelyst::Action.

Definition at line 42 of file actionchain.cpp.

References ActionChain().