m2etis
0.4
|
#include <BruteForcePartition.h>
Public Types | |
typedef boost::shared_ptr< EventType > | PayloadPtr |
Public Types inherited from m2etis::pubsub::partition::BasePartition< NetworkType, EventType > | |
typedef boost::shared_ptr< EventType > | PayloadPtr |
Public Member Functions | |
BruteForcePartition () | |
BruteForcePartition (const std::vector< boost::shared_ptr< filter::FilterExp< EventType >> > &partition_filter_vector) | |
virtual | ~BruteForcePartition () |
void | createRendezvousPartition (const typename NetworkType::Key &) |
creates a base partition for the RP (dynamic) More... | |
std::vector< int > | getTreeNames () |
returns amount of partitions this strategy contains (static & dynamic) More... | |
std::vector< int >::size_type | getPublishTree (const PayloadPtr message, const typename NetworkType::Key &) |
returns the tree index the given node with the given payload should publish on (static & dynamic) More... | |
std::vector< unsigned int > | getSubscribeTrees (boost::shared_ptr< filter::FilterExp< EventType > > dynamic_filter) |
boost::shared_ptr< filter::FilterExp< EventType > > | getPredicate (size_t id) |
returns the predicate for the given partition id (dynamic) More... | |
bool | createPartition (const typename NetworkType::Key &) |
can create a new partition for this channel if a new node (root) joins, return true, if a new partition was created, otherwise false (dynamic) More... | |
void | addPartition (boost::shared_ptr< filter::FilterExp< EventType >>, const typename NetworkType::Key &) |
void | removePartition (size_t) |
removes the partition with the given id (dynamic) More... | |
void | changePredicate (size_t, boost::shared_ptr< filter::FilterExp< EventType >>) |
changes the filter predicate for the partition with the given id (dynamic) More... | |
void | changeRoot (size_t, typename NetworkType::Key &) |
Public Member Functions inherited from m2etis::pubsub::partition::BasePartition< NetworkType, EventType > | |
BasePartition () | |
virtual | ~BasePartition () |
virtual std::vector< unsigned int > | getSubscribeTrees (boost::shared_ptr< filter::FilterExp< EventType >> dynamic_filter)=0 |
returns the tree indices of all trees matching the predicate to subscribe on (static & dynamic) More... | |
virtual void | addPartition (boost::shared_ptr< filter::FilterExp< EventType > > predicate, const typename NetworkType::Key &root)=0 |
adds a new partition to the strategy at nodes not being RP (dynamic) More... | |
virtual std::string | toString () |
Static Public Attributes | |
static const bool | DYNAMIC_PARTITION |
Definition at line 36 of file BruteForcePartition.h.
typedef boost::shared_ptr<EventType> m2etis::pubsub::partition::BruteForcePartition< NetworkType, EventType >::PayloadPtr |
Definition at line 38 of file BruteForcePartition.h.
|
inline |
Definition at line 42 of file BruteForcePartition.h.
|
inlineexplicit |
Definition at line 45 of file BruteForcePartition.h.
|
inlinevirtual |
Definition at line 48 of file BruteForcePartition.h.
|
inline |
Definition at line 113 of file BruteForcePartition.h.
|
inlinevirtual |
changes the filter predicate for the partition with the given id (dynamic)
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 119 of file BruteForcePartition.h.
|
inlinevirtual |
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 122 of file BruteForcePartition.h.
|
inlinevirtual |
can create a new partition for this channel if a new node (root) joins, return true, if a new partition was created, otherwise false (dynamic)
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 109 of file BruteForcePartition.h.
|
inlinevirtual |
creates a base partition for the RP (dynamic)
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 50 of file BruteForcePartition.h.
|
inlinevirtual |
returns the predicate for the given partition id (dynamic)
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 104 of file BruteForcePartition.h.
|
inlinevirtual |
returns the tree index the given node with the given payload should publish on (static & dynamic)
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 67 of file BruteForcePartition.h.
|
inline |
Definition at line 87 of file BruteForcePartition.h.
|
inlinevirtual |
returns amount of partitions this strategy contains (static & dynamic)
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 54 of file BruteForcePartition.h.
|
inlinevirtual |
removes the partition with the given id (dynamic)
Implements m2etis::pubsub::partition::BasePartition< NetworkType, EventType >.
Definition at line 116 of file BruteForcePartition.h.
|
static |
Definition at line 40 of file BruteForcePartition.h.