basic message cleaner, not configurable yet
This commit is contained in:
		| @@ -2,11 +2,15 @@ cmake_minimum_required(VERSION 3.9 FATAL_ERROR) | |||||||
|  |  | ||||||
| add_executable(totato | add_executable(totato | ||||||
| 	./main.cpp | 	./main.cpp | ||||||
|  |  | ||||||
| 	./tox_client.hpp | 	./tox_client.hpp | ||||||
| 	./tox_client.cpp | 	./tox_client.cpp | ||||||
| 	./tox_private_impl.hpp | 	./tox_private_impl.hpp | ||||||
| 	./auto_dirty.hpp | 	./auto_dirty.hpp | ||||||
| 	./auto_dirty.cpp | 	./auto_dirty.cpp | ||||||
|  |  | ||||||
|  | 	./message_cleanser.hpp | ||||||
|  | 	./message_cleanser.cpp | ||||||
| ) | ) | ||||||
|  |  | ||||||
| target_compile_features(totato PUBLIC cxx_std_17) | target_compile_features(totato PUBLIC cxx_std_17) | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ | |||||||
|  |  | ||||||
| #include "./tox_client.hpp" | #include "./tox_client.hpp" | ||||||
| #include "./auto_dirty.hpp" | #include "./auto_dirty.hpp" | ||||||
|  | #include "./message_cleanser.hpp" | ||||||
|  |  | ||||||
| #include <nlohmann/json.hpp> | #include <nlohmann/json.hpp> | ||||||
|  |  | ||||||
| @@ -156,6 +157,7 @@ int main(int argc, char** argv) { | |||||||
| 	Contact3Registry cr; | 	Contact3Registry cr; | ||||||
| 	RegistryMessageModel rmm{cr}; | 	RegistryMessageModel rmm{cr}; | ||||||
| 	MessageTimeSort mts{rmm}; | 	MessageTimeSort mts{rmm}; | ||||||
|  | 	MessageCleanser mc{cr, rmm}; | ||||||
|  |  | ||||||
| 	PluginManager pm; | 	PluginManager pm; | ||||||
|  |  | ||||||
| @@ -173,6 +175,8 @@ int main(int argc, char** argv) { | |||||||
| 		tc.setSelfName(name); // TODO: this is ugly | 		tc.setSelfName(name); // TODO: this is ugly | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	std::cout << "TOTATO: own address: " << tc.toxSelfGetAddressStr() << "\n"; | ||||||
|  |  | ||||||
| 	ToxPrivateImpl tpi{tc.getTox()}; | 	ToxPrivateImpl tpi{tc.getTox()}; | ||||||
| 	AutoDirty ad{tc}; | 	AutoDirty ad{tc}; | ||||||
| 	ToxContactModel2 tcm{cr, tc, tc}; | 	ToxContactModel2 tcm{cr, tc, tc}; | ||||||
| @@ -229,6 +233,8 @@ int main(int argc, char** argv) { | |||||||
|  |  | ||||||
| 		pm.tick(/*time_delta*/0.02f); | 		pm.tick(/*time_delta*/0.02f); | ||||||
|  |  | ||||||
|  | 		mc.iterate(0.02f); | ||||||
|  |  | ||||||
| 		//std::this_thread::sleep_for( // time left to get to 60fps | 		//std::this_thread::sleep_for( // time left to get to 60fps | ||||||
| 			//std::chrono::duration<float, std::chrono::seconds::period>(0.0166f) // 60fps frame duration | 			//std::chrono::duration<float, std::chrono::seconds::period>(0.0166f) // 60fps frame duration | ||||||
| 			//- std::chrono::duration<float, std::chrono::seconds::period>(std::chrono::steady_clock::now() - new_time) // time used for rendering | 			//- std::chrono::duration<float, std::chrono::seconds::period>(std::chrono::steady_clock::now() - new_time) // time used for rendering | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								src/message_cleanser.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								src/message_cleanser.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | |||||||
|  | #include "./message_cleanser.hpp" | ||||||
|  |  | ||||||
|  | #include <solanaceae/contact/components.hpp> | ||||||
|  | #include <solanaceae/message3/components.hpp> | ||||||
|  |  | ||||||
|  | #include <iostream> | ||||||
|  | #include <chrono> | ||||||
|  |  | ||||||
|  | MessageCleanser::MessageCleanser(Contact3Registry& cr, RegistryMessageModel& rmm) : _cr(cr), _rmm(rmm) { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | MessageCleanser::~MessageCleanser(void) { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void MessageCleanser::iterate(float time_delta) { | ||||||
|  | 	_timer += time_delta; | ||||||
|  | 	if (_timer >= _interval) { | ||||||
|  | 		_timer = 0.f; | ||||||
|  |  | ||||||
|  | 		//std::cout << "MC: cleaning up old messages...\n"; | ||||||
|  |  | ||||||
|  | 		uint64_t now_ts = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count(); | ||||||
|  |  | ||||||
|  | 		uint64_t deleted_count{0}; | ||||||
|  |  | ||||||
|  | 		// TODO: iterate rmm directly | ||||||
|  | 		//_rmm.get(); | ||||||
|  | 		// workaround by iterating contacts | ||||||
|  | 		for (const auto& c : _cr.view<Contact::Components::TagBig>()) { | ||||||
|  | 			if (auto* reg = _rmm.get(c); reg != nullptr) { | ||||||
|  | 				std::vector<Message3> to_remove; | ||||||
|  | 				// assuming all messages have Timestamp comp | ||||||
|  | 				reg->view<Message::Components::Timestamp>().each([this, now_ts, &to_remove](const Message3 ent, const Message::Components::Timestamp& ts) { | ||||||
|  | 					if (now_ts >= ts.ts + static_cast<uint64_t>(_old_age*1000.f)) { | ||||||
|  | 						to_remove.push_back(ent); | ||||||
|  | 					} | ||||||
|  | 				}); | ||||||
|  |  | ||||||
|  | 				reg->destroy(to_remove.cbegin(), to_remove.cend()); | ||||||
|  | 				deleted_count += to_remove.size(); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if (deleted_count > 0) { | ||||||
|  | 			std::cout << "MC: cleaned up " << deleted_count << "\n"; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										18
									
								
								src/message_cleanser.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								src/message_cleanser.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include <solanaceae/message3/registry_message_model.hpp> | ||||||
|  |  | ||||||
|  | class MessageCleanser { | ||||||
|  | 	Contact3Registry& _cr; | ||||||
|  | 	RegistryMessageModel& _rmm; | ||||||
|  |  | ||||||
|  | 	float _old_age{150.f*60.f}; // max 150min | ||||||
|  | 	float _interval{3.f*60.f}; // every 3min | ||||||
|  | 	float _timer{0.f}; | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		MessageCleanser(Contact3Registry& cr, RegistryMessageModel& rmm); | ||||||
|  | 		~MessageCleanser(void); | ||||||
|  |  | ||||||
|  | 		void iterate(float time_delta); | ||||||
|  | }; | ||||||
		Reference in New Issue
	
	Block a user