evtc\agent/realtime.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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
//! Realtime API [`Agent`] types.
use super::AgentKind;
use std::{ffi::CStr, os::raw::c_char};
#[cfg(feature = "serde")]
use serde::{Deserialize, Serialize};
/// Represents an agent in a realtime combat event.
///
/// Names are available for the duration of the fight.
/// Due to this, this struct is not usable for longer than the function call.
/// If you need it for longer than its lifetime, consider converting it to [`AgentOwned`].
///
/// ```no_run
/// # use evtc::agent::realtime::{Agent, AgentOwned};
/// # let agent: &Agent = todo!();
/// let owned = agent.to_owned();
/// let owned: AgentOwned = agent.into();
/// ```
#[derive(Debug)]
pub struct Agent {
/// Name of the agent.
name: *const c_char,
/// Unique id.
pub id: usize,
/// Profession of the agent.
pub prof: u32,
/// Elite (specialization) of the agent.
pub elite: u32,
/// Whether the agent is self (the local player).
pub is_self: u32,
/// Team the agent is in.
pub team: u16,
}
impl Agent {
/// Returns the agent's name.
#[inline]
pub fn name(&self) -> Option<&str> {
if !self.name.is_null() {
unsafe { CStr::from_ptr(self.name) }.to_str().ok()
} else {
None
}
}
/// Returns the raw pointer to the agent's name.
#[inline]
pub fn name_ptr(&self) -> *const c_char {
self.name
}
/// Converts the [`Agent`] to the owned version [`AgentOwned`].
#[inline]
pub fn to_owned(&self) -> AgentOwned {
self.into()
}
/// Determines the kind of agent.
#[inline]
pub const fn kind(&self) -> AgentKind {
AgentKind::new(self.prof, self.elite)
}
}
/// [`Agent`] with an owned [`String`] name.
#[derive(Debug, Clone)]
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
pub struct AgentOwned {
/// Name of the agent.
pub name: Option<String>,
/// Unique id.
pub id: usize,
/// Profession of the agent.
pub prof: u32,
/// Elite (specialization) of the agent.
pub elite: u32,
/// Whether the agent is self (the local player).
pub is_self: u32,
/// Team the agent is in.
pub team: u16,
}
impl From<Agent> for AgentOwned {
#[inline]
fn from(agent: Agent) -> Self {
(&agent).into()
}
}
impl From<&Agent> for AgentOwned {
#[inline]
fn from(agent: &Agent) -> Self {
Self {
name: agent.name().map(|string| string.to_owned()),
id: agent.id,
prof: agent.prof,
elite: agent.elite,
is_self: agent.is_self,
team: agent.team,
}
}
}