132 lines
4.2 KiB
C++
132 lines
4.2 KiB
C++
#pragma once
|
|
#ifndef EVENT_MANAGER_H_INCLUDED
|
|
#define EVENT_MANAGER_H_INCLUDED
|
|
|
|
#include "Core.h"
|
|
#include "Export.h"
|
|
#include "ColorText.h"
|
|
#include "PluginManager.h"
|
|
#include "Console.h"
|
|
#include "DataDefs.h"
|
|
|
|
#include "df/coord.h"
|
|
#include "df/unit.h"
|
|
#include "df/unit_inventory_item.h"
|
|
#include "df/unit_wound.h"
|
|
|
|
namespace DFHack {
|
|
namespace EventManager {
|
|
namespace EventType {
|
|
// NOTICE: keep this list synchronized with the eventHandlers array
|
|
// in plugins/eventful.cpp or else events will go to the wrong
|
|
// handlers.
|
|
enum EventType {
|
|
TICK,
|
|
JOB_INITIATED,
|
|
JOB_STARTED, //has a worker
|
|
JOB_COMPLETED,
|
|
UNIT_NEW_ACTIVE,
|
|
UNIT_DEATH,
|
|
ITEM_CREATED,
|
|
BUILDING,
|
|
CONSTRUCTION,
|
|
SYNDROME,
|
|
INVASION,
|
|
INVENTORY_CHANGE,
|
|
REPORT,
|
|
UNIT_ATTACK,
|
|
UNLOAD,
|
|
INTERACTION,
|
|
EVENT_MAX
|
|
};
|
|
}
|
|
|
|
struct EventHandler {
|
|
typedef void (*callback_t)(color_ostream&, void*); //called when the event happens
|
|
callback_t eventHandler;
|
|
int32_t freq; //how often event is allowed to fire (in ticks) use 0 to always fire when possible
|
|
|
|
EventHandler(callback_t eventHandlerIn, int32_t freqIn): eventHandler(eventHandlerIn), freq(freqIn) {
|
|
}
|
|
|
|
bool operator==(const EventHandler& handle) const {
|
|
return eventHandler == handle.eventHandler && freq == handle.freq;
|
|
}
|
|
bool operator!=(const EventHandler& handle) const {
|
|
return !( *this == handle);
|
|
}
|
|
};
|
|
|
|
struct SyndromeData {
|
|
int32_t unitId;
|
|
int32_t syndromeIndex;
|
|
SyndromeData(int32_t unitId_in, int32_t syndromeIndex_in): unitId(unitId_in), syndromeIndex(syndromeIndex_in) {
|
|
|
|
}
|
|
};
|
|
|
|
struct InventoryItem {
|
|
//it has to keep the id of an item because the item itself may have been deallocated
|
|
int32_t itemId;
|
|
df::unit_inventory_item item;
|
|
InventoryItem() {}
|
|
InventoryItem(int32_t id_in, df::unit_inventory_item item_in): itemId(id_in), item(item_in) {}
|
|
};
|
|
struct InventoryChangeData {
|
|
int32_t unitId;
|
|
InventoryItem* item_old;
|
|
InventoryItem* item_new;
|
|
InventoryChangeData() {}
|
|
InventoryChangeData(int32_t id_in, InventoryItem* old_in, InventoryItem* new_in): unitId(id_in), item_old(old_in), item_new(new_in) {}
|
|
};
|
|
|
|
struct UnitAttackData {
|
|
int32_t attacker;
|
|
int32_t defender;
|
|
int32_t wound;
|
|
};
|
|
|
|
struct InteractionData {
|
|
std::string attackVerb;
|
|
std::string defendVerb;
|
|
int32_t attacker;
|
|
int32_t defender;
|
|
int32_t attackReport;
|
|
int32_t defendReport;
|
|
};
|
|
|
|
DFHACK_EXPORT void registerListener(EventType::EventType e, EventHandler handler, Plugin* plugin);
|
|
DFHACK_EXPORT int32_t registerTick(EventHandler handler, int32_t when, Plugin* plugin, bool absolute=false);
|
|
DFHACK_EXPORT void unregister(EventType::EventType e, EventHandler handler, Plugin* plugin);
|
|
DFHACK_EXPORT void unregisterAll(Plugin* plugin);
|
|
void manageEvents(color_ostream& out);
|
|
void onStateChange(color_ostream& out, state_change_event event);
|
|
}
|
|
}
|
|
|
|
namespace std {
|
|
template <>
|
|
struct hash<df::coord> {
|
|
std::size_t operator()(const df::coord& c) const {
|
|
size_t r = 17;
|
|
const size_t m = 65537;
|
|
r = m*(r+c.x);
|
|
r = m*(r+c.y);
|
|
r = m*(r+c.z);
|
|
return r;
|
|
}
|
|
};
|
|
template <>
|
|
struct hash<DFHack::EventManager::EventHandler> {
|
|
std::size_t operator()(const DFHack::EventManager::EventHandler& h) const {
|
|
size_t r = 17;
|
|
const size_t m = 65537;
|
|
r = m*(r+(intptr_t)h.eventHandler);
|
|
r = m*(r+h.freq);
|
|
return r;
|
|
}
|
|
};
|
|
}
|
|
|
|
#endif
|