#pragma once #include #include #include #include #include struct ReceivingTransfers { struct Entry { struct Info { ObjectHandle content; // copy of info data // too large? std::vector info_data; }; struct Chunk { ObjectHandle content; std::vector chunk_indices; // or data? // if memmapped, this would be just a pointer }; std::variant v; float time_since_activity {0.f}; bool isInfo(void) const { return std::holds_alternative(v); } bool isChunk(void) const { return std::holds_alternative(v); } Info& getInfo(void) { return std::get(v); } const Info& getInfo(void) const { return std::get(v); } Chunk& getChunk(void) { return std::get(v); } const Chunk& getChunk(void) const { return std::get(v); } }; // key is groupid + peerid // TODO: replace with contact //using ReceivingTransfers = entt::dense_map>; entt::dense_map> _data; void tick(float delta); Entry& emplaceInfo(uint64_t combined_id, uint8_t transfer_id, const Entry::Info& info); Entry& emplaceChunk(uint64_t combined_id, uint8_t transfer_id, const Entry::Chunk& chunk); bool containsPeer(uint64_t combined_id) const { return _data.count(combined_id); } bool containsPeerTransfer(uint64_t combined_id, uint8_t transfer_id) const; bool containsChunk(ObjectHandle o, size_t chunk_idx) const; bool containsPeerChunk(uint64_t combined_id, ObjectHandle o, size_t chunk_idx) const; auto& getPeer(uint64_t combined_id) { return _data.at(combined_id); } auto& getTransfer(uint64_t combined_id, uint8_t transfer_id) { return getPeer(combined_id).at(transfer_id); } void removePeer(uint64_t combined_id); void removePeerTransfer(uint64_t combined_id, uint8_t transfer_id); size_t size(void) const; size_t sizePeer(uint64_t combined_id) const; };