evtc\agent/id.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
use crate::event::Event;
#[cfg(feature = "serde")]
use serde::{Deserialize, Serialize};
/// Ids for an agent.
#[derive(Debug, Clone)]
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
pub struct AgentId {
/// Agent id as assigned by Arc.
pub id: u64,
/// Instance id of the agent as appears in game at time of event.
pub instance_id: u16,
/// If agent has a master (e.g. is minion), will be equal to instance id of master, zero otherwise.
pub master_instance_id: u16,
}
impl AgentId {
/// Creates new agent id information.
#[inline]
pub const fn new(id: u64, instance_id: u16, master_instance_id: u16) -> Self {
Self {
id,
instance_id,
master_instance_id,
}
}
/// Creates new agent id information without a master.
#[inline]
pub const fn without_master(id: u64, instance_id: u16) -> Self {
Self::new(id, instance_id, 0)
}
/// Creates new agent id information from the [`Event`] source agent.
#[inline]
pub const fn from_src(event: &Event) -> Self {
Self::new(
event.src_agent,
event.src_instance_id,
event.src_master_instance_id,
)
}
/// Creates new agent id information from the [`Event`] destination agent.
#[inline]
pub const fn from_dst(event: &Event) -> Self {
Self::new(
event.dst_agent,
event.dst_instance_id,
event.dst_master_instance_id,
)
}
/// Returns whether the agent has a master.
#[inline]
pub const fn has_master(&self) -> bool {
self.master_instance_id != 0
}
}