2024-06-10 20:11:25 +02:00
|
|
|
#include "./factorio.hpp"
|
2024-06-12 21:11:12 +02:00
|
|
|
|
|
|
|
#include <solanaceae/util/config_model.hpp>
|
|
|
|
#include <solanaceae/util/utils.hpp>
|
2024-06-10 20:11:25 +02:00
|
|
|
|
|
|
|
#include <solanaceae/message3/components.hpp>
|
|
|
|
#include <solanaceae/contact/components.hpp>
|
|
|
|
|
2024-06-12 21:30:51 +02:00
|
|
|
void Factorio::sendToLinked(const std::string& message) {
|
|
|
|
for (const auto& h : _linked_contacts) {
|
|
|
|
if (!static_cast<bool>(h)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
_rmm.sendText(h, message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-12 21:11:12 +02:00
|
|
|
Factorio::Factorio(ConfigModelI& conf, Contact3Registry& cr, RegistryMessageModel& rmm, FactorioLogParser& flp) :
|
2024-06-10 22:27:19 +02:00
|
|
|
_cr(cr),
|
2024-06-11 10:09:55 +02:00
|
|
|
_rmm(rmm),
|
|
|
|
_flp(flp)
|
2024-06-10 22:27:19 +02:00
|
|
|
{
|
2024-06-12 21:11:12 +02:00
|
|
|
// config
|
|
|
|
for (const auto&& [contact_id, enabled] : conf.entries_bool("Factorio", "link_to_contact")) {
|
|
|
|
//std::cout << "config id:" << contact_id << " e:" << enabled << "\n";
|
|
|
|
|
|
|
|
const auto id_vec = hex2bin(contact_id);
|
|
|
|
|
|
|
|
// search
|
|
|
|
Contact3Handle h;
|
|
|
|
auto view = _cr.view<Contact::Components::ID>();
|
|
|
|
for (const auto c : view) {
|
|
|
|
if (view.get<Contact::Components::ID>(c).data == id_vec) {
|
|
|
|
h = Contact3Handle{_cr, c};
|
|
|
|
std::cout << "Factorio: found contact for link.\n";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!static_cast<bool>(h)) {
|
|
|
|
// not found, create thin contact with just id
|
|
|
|
h = {_cr, _cr.create()};
|
|
|
|
h.emplace<Contact::Components::ID>(id_vec);
|
|
|
|
std::cout << "Factorio: contact not found, created thin contact from ID. (" << contact_id << ")\n";
|
|
|
|
}
|
|
|
|
_linked_contacts.push_back(h);
|
|
|
|
}
|
|
|
|
|
2024-06-10 20:11:25 +02:00
|
|
|
_rmm.subscribe(this, RegistryMessageModel_Event::message_construct);
|
2024-06-11 10:09:55 +02:00
|
|
|
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::join);
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::leave);
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::chat);
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::died);
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::evolution);
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::research_started);
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::research_finished);
|
|
|
|
_flp.subscribe(this, FactorioLogParser_Event::research_cancelled);
|
2024-06-10 20:11:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Factorio::~Factorio(void) {
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const Message::Events::MessageConstruct& e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2024-06-11 10:09:55 +02:00
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::Join& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event join " << e.player_name << "\n";
|
2024-06-12 21:30:51 +02:00
|
|
|
|
|
|
|
std::string message{e.player_name};
|
|
|
|
message += " joined";
|
|
|
|
|
|
|
|
sendToLinked(message);
|
|
|
|
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::Leave& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event leave " << e.player_name << " " << e.reason << "\n";
|
2024-06-12 21:30:51 +02:00
|
|
|
|
|
|
|
std::string message{e.player_name};
|
|
|
|
message += " left";
|
|
|
|
|
|
|
|
sendToLinked(message);
|
|
|
|
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::Chat& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event chat " << e.player_name << ": " << e.message << "\n";
|
2024-06-12 21:30:51 +02:00
|
|
|
|
|
|
|
std::string message{"<"};
|
|
|
|
message += e.player_name;
|
|
|
|
message += ">: ";
|
|
|
|
message += e.message;
|
|
|
|
|
|
|
|
sendToLinked(message);
|
|
|
|
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::Died& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event died " << e.player_name << ": " << e.reason << "\n";
|
2024-06-12 21:30:51 +02:00
|
|
|
|
|
|
|
std::string message{e.player_name};
|
|
|
|
message += " died from ";
|
|
|
|
message += e.reason;
|
|
|
|
|
|
|
|
sendToLinked(message);
|
|
|
|
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::Evolution& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event evolution " << e.evo << "\n";
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::ResearchStarted& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event research started " << e.name << "\n";
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::ResearchFinished& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event research finished " << e.name << "\n";
|
2024-06-12 21:30:51 +02:00
|
|
|
|
|
|
|
std::string message{"Research "};
|
|
|
|
message += e.name;
|
|
|
|
message += " finished!";
|
|
|
|
|
|
|
|
sendToLinked(message);
|
|
|
|
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Factorio::onEvent(const FactorioLog::Events::ResearchCancelled& e) {
|
2024-06-12 21:11:12 +02:00
|
|
|
std::cout << "Factorio: event research cancelled " << e.name << "\n";
|
2024-06-11 10:09:55 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|