[300] | 1 | #ifndef __EVENT_CLIENT_HPP__ |
---|
| 2 | #define __EVENT_CLIENT_HPP__ |
---|
| 3 | |
---|
[591] | 4 | #include "xios_spl.hpp" |
---|
[367] | 5 | #include "buffer_out.hpp" |
---|
| 6 | #include "message.hpp" |
---|
[300] | 7 | |
---|
[335] | 8 | namespace xios |
---|
[300] | 9 | { |
---|
| 10 | class CEventClient |
---|
| 11 | { |
---|
| 12 | public: |
---|
[731] | 13 | static const size_t headerSize; |
---|
[300] | 14 | |
---|
[731] | 15 | CEventClient(int classId, int typeId); |
---|
[300] | 16 | |
---|
[731] | 17 | void push(int rank, int nbSender, CMessage& msg); |
---|
| 18 | void send(size_t timeLine, const std::list<int>& sizes, std::list<CBufferOut*>&); |
---|
| 19 | bool isEmpty(void); |
---|
| 20 | std::list<int> getRanks(void); |
---|
| 21 | std::list<int> getSizes(void); |
---|
[1377] | 22 | int getClassId(void) { return classId; } |
---|
| 23 | int getTypeId(void) { return typeId; } |
---|
| 24 | |
---|
[2343] | 25 | void setFirst(void) |
---|
| 26 | { |
---|
| 27 | itRanks=ranks.begin() ; |
---|
| 28 | itNbSenders=nbSenders.begin() ; |
---|
| 29 | itMessages=messages.begin() ; |
---|
| 30 | } |
---|
| 31 | |
---|
| 32 | bool isFirst(void) |
---|
| 33 | { |
---|
| 34 | return itRanks==ranks.begin() ; |
---|
| 35 | } |
---|
| 36 | |
---|
| 37 | void next(void) |
---|
| 38 | { |
---|
| 39 | itRanks++ ; |
---|
| 40 | if (itRanks==ranks.end()) itRanks=ranks.begin() ; |
---|
| 41 | itNbSenders++ ; |
---|
| 42 | if (itNbSenders==nbSenders.end()) itNbSenders=nbSenders.begin() ; |
---|
| 43 | itMessages++ ; |
---|
| 44 | if (itMessages==messages.end()) itMessages=messages.begin() ; |
---|
| 45 | } |
---|
| 46 | |
---|
| 47 | void remove(void) |
---|
| 48 | { |
---|
| 49 | auto removedRank = itRanks; |
---|
| 50 | itRanks++ ; |
---|
| 51 | ranks.erase(removedRank) ; |
---|
| 52 | if (itRanks==ranks.end()) itRanks=ranks.begin() ; |
---|
| 53 | |
---|
| 54 | auto removedNbSender = itNbSenders ; |
---|
| 55 | itNbSenders++ ; |
---|
| 56 | nbSenders.erase(removedNbSender) ; |
---|
| 57 | if (itNbSenders==nbSenders.end()) itNbSenders=nbSenders.begin() ; |
---|
| 58 | |
---|
| 59 | auto removedMessage = itMessages ; |
---|
| 60 | itMessages++ ; |
---|
| 61 | messages.erase(removedMessage) ; |
---|
| 62 | if (itMessages==messages.end()) itMessages=messages.begin() ; |
---|
| 63 | } |
---|
| 64 | |
---|
| 65 | int getRank(void) { return *itRanks ;} |
---|
| 66 | int getNbSender(void) { return *itNbSenders ;} |
---|
| 67 | int getSize(void) { return (*itMessages)->size() + headerSize;} |
---|
| 68 | void send(size_t timeLine, int size, CBufferOut* buffer) ; |
---|
[731] | 69 | private: |
---|
| 70 | int classId; |
---|
| 71 | int typeId; |
---|
| 72 | std::list<int> ranks; |
---|
| 73 | std::list<int> nbSenders; |
---|
| 74 | std::list<CMessage*> messages; |
---|
[2343] | 75 | |
---|
| 76 | std::list<int>::iterator itRanks; |
---|
| 77 | std::list<int>::iterator itNbSenders; |
---|
| 78 | std::list<CMessage*>::iterator itMessages; |
---|
[731] | 79 | }; |
---|
[300] | 80 | } |
---|
| 81 | |
---|
| 82 | #endif |
---|