wow_world_base 0.3.0

Base definitions and functions for World of Warcraft game servers
Documentation
/// Auto generated from the original `wowm` in file [`wow_message_parser/wowm/world/movement/smsg/smsg_transfer_aborted.wowm:56`](https://github.com/gtker/wow_messages/tree/main/wow_message_parser/wowm/world/movement/smsg/smsg_transfer_aborted.wowm#L56):
/// ```text
/// enum TransferAbortReason : u8 {
///     NONE = 0x00;
///     ERROR = 0x01;
///     MAX_PLAYERS = 0x02;
///     NOT_FOUND = 0x03;
///     TOO_MANY_INSTANCES = 0x04;
///     ZONE_IN_COMBAT = 0x06;
///     INSUFFICIENT_EXPANSION_LEVEL = 0x07;
///     DIFFICULTY_NOT_AVAILABLE = 0x08;
///     UNIQUE_MESSAGE = 0x09;
///     TOO_MANY_REALM_INSTANCES = 0x0A;
///     NEED_GROUP = 0x0B;
///     NOT_FOUND1 = 0x0C;
///     NOT_FOUND2 = 0x0D;
///     NOT_FOUND3 = 0x0E;
///     REALM_ONLY = 0x0F;
///     MAP_NOT_ALLOWED = 0x10;
/// }
/// ```
#[derive(Debug, PartialEq, Eq, Hash, Ord, PartialOrd, Copy, Clone)]
#[cfg_attr(feature = "serde", derive(serde::Deserialize, serde::Serialize))]
pub enum TransferAbortReason {
    None,
    ErrorX,
    /// Transfer Aborted: instance is full
    MaxPlayers,
    /// Transfer Aborted: instance not found
    NotFound,
    /// You have entered too many instances recently.
    TooManyInstances,
    /// Unable to zone in while an encounter is in progress.
    ZoneInCombat,
    /// You must have TBC/WotLK expansion installed to access this area.
    InsufficientExpansionLevel,
    /// Normal/Heroic/Epic difficulty mode is not available for %s.
    DifficultyNotAvailable,
    /// Until you've escaped The Lich Kings grasp, you cannot leave this place!
    UniqueMessage,
    /// Additional instances cannot be launched, please try again later.
    TooManyRealmInstances,
    /// 3.1
    NeedGroup,
    /// 3.1
    NotFound1,
    /// 3.1
    NotFound2,
    /// 3.2
    NotFound3,
    /// All players on party must be from the same realm.
    RealmOnly,
    /// Map can't be entered at this time.
    MapNotAllowed,
}

impl TransferAbortReason {
    pub const fn as_int(&self) -> u8 {
        match self {
            Self::None => 0x0,
            Self::ErrorX => 0x1,
            Self::MaxPlayers => 0x2,
            Self::NotFound => 0x3,
            Self::TooManyInstances => 0x4,
            Self::ZoneInCombat => 0x6,
            Self::InsufficientExpansionLevel => 0x7,
            Self::DifficultyNotAvailable => 0x8,
            Self::UniqueMessage => 0x9,
            Self::TooManyRealmInstances => 0xa,
            Self::NeedGroup => 0xb,
            Self::NotFound1 => 0xc,
            Self::NotFound2 => 0xd,
            Self::NotFound3 => 0xe,
            Self::RealmOnly => 0xf,
            Self::MapNotAllowed => 0x10,
        }
    }

    pub const fn variants() -> [Self; 16] {
        [
            Self::None,
            Self::ErrorX,
            Self::MaxPlayers,
            Self::NotFound,
            Self::TooManyInstances,
            Self::ZoneInCombat,
            Self::InsufficientExpansionLevel,
            Self::DifficultyNotAvailable,
            Self::UniqueMessage,
            Self::TooManyRealmInstances,
            Self::NeedGroup,
            Self::NotFound1,
            Self::NotFound2,
            Self::NotFound3,
            Self::RealmOnly,
            Self::MapNotAllowed,
        ]
    }

    pub const fn from_int(value: u8) -> Result<Self, crate::errors::EnumError> {
        match value {
            0 => Ok(Self::None),
            1 => Ok(Self::ErrorX),
            2 => Ok(Self::MaxPlayers),
            3 => Ok(Self::NotFound),
            4 => Ok(Self::TooManyInstances),
            6 => Ok(Self::ZoneInCombat),
            7 => Ok(Self::InsufficientExpansionLevel),
            8 => Ok(Self::DifficultyNotAvailable),
            9 => Ok(Self::UniqueMessage),
            10 => Ok(Self::TooManyRealmInstances),
            11 => Ok(Self::NeedGroup),
            12 => Ok(Self::NotFound1),
            13 => Ok(Self::NotFound2),
            14 => Ok(Self::NotFound3),
            15 => Ok(Self::RealmOnly),
            16 => Ok(Self::MapNotAllowed),
            v => Err(crate::errors::EnumError::new(NAME, v as i128),)
        }
    }
}

#[cfg(feature = "print-testcase")]
impl TransferAbortReason {
    pub const fn as_test_case_value(&self) -> &'static str {
        match self {
            Self::None => "NONE",
            Self::ErrorX => "ERROR",
            Self::MaxPlayers => "MAX_PLAYERS",
            Self::NotFound => "NOT_FOUND",
            Self::TooManyInstances => "TOO_MANY_INSTANCES",
            Self::ZoneInCombat => "ZONE_IN_COMBAT",
            Self::InsufficientExpansionLevel => "INSUFFICIENT_EXPANSION_LEVEL",
            Self::DifficultyNotAvailable => "DIFFICULTY_NOT_AVAILABLE",
            Self::UniqueMessage => "UNIQUE_MESSAGE",
            Self::TooManyRealmInstances => "TOO_MANY_REALM_INSTANCES",
            Self::NeedGroup => "NEED_GROUP",
            Self::NotFound1 => "NOT_FOUND1",
            Self::NotFound2 => "NOT_FOUND2",
            Self::NotFound3 => "NOT_FOUND3",
            Self::RealmOnly => "REALM_ONLY",
            Self::MapNotAllowed => "MAP_NOT_ALLOWED",
        }
    }

}

const NAME: &str = "TransferAbortReason";

impl Default for TransferAbortReason {
    fn default() -> Self {
        Self::None
    }
}

impl std::fmt::Display for TransferAbortReason {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        match self {
            Self::None => f.write_str("None"),
            Self::ErrorX => f.write_str("ErrorX"),
            Self::MaxPlayers => f.write_str("MaxPlayers"),
            Self::NotFound => f.write_str("NotFound"),
            Self::TooManyInstances => f.write_str("TooManyInstances"),
            Self::ZoneInCombat => f.write_str("ZoneInCombat"),
            Self::InsufficientExpansionLevel => f.write_str("InsufficientExpansionLevel"),
            Self::DifficultyNotAvailable => f.write_str("DifficultyNotAvailable"),
            Self::UniqueMessage => f.write_str("UniqueMessage"),
            Self::TooManyRealmInstances => f.write_str("TooManyRealmInstances"),
            Self::NeedGroup => f.write_str("NeedGroup"),
            Self::NotFound1 => f.write_str("NotFound1"),
            Self::NotFound2 => f.write_str("NotFound2"),
            Self::NotFound3 => f.write_str("NotFound3"),
            Self::RealmOnly => f.write_str("RealmOnly"),
            Self::MapNotAllowed => f.write_str("MapNotAllowed"),
        }
    }
}

impl TryFrom<u8> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: u8) -> Result<Self, Self::Error> {
        Self::from_int(value)
    }
}

impl TryFrom<u16> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: u16) -> Result<Self, Self::Error> {
        TryInto::<u8>::try_into(value)
            .map_err(|_| crate::errors::EnumError::new(NAME, value.into()))?
            .try_into()
    }
}

impl TryFrom<u32> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: u32) -> Result<Self, Self::Error> {
        TryInto::<u8>::try_into(value)
            .map_err(|_| crate::errors::EnumError::new(NAME, value.into()))?
            .try_into()
    }
}

impl TryFrom<u64> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: u64) -> Result<Self, Self::Error> {
        TryInto::<u8>::try_into(value)
            .map_err(|_| crate::errors::EnumError::new(NAME, value.into()))?
            .try_into()
    }
}

impl TryFrom<i8> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: i8) -> Result<Self, Self::Error> {
        let v = u8::from_le_bytes(value.to_le_bytes());
        Self::from_int(v)
    }
}

impl TryFrom<i16> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: i16) -> Result<Self, Self::Error> {
        TryInto::<u8>::try_into(value)
            .map_err(|_| crate::errors::EnumError::new(NAME, value.into()))?
            .try_into()
    }
}

impl TryFrom<i32> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: i32) -> Result<Self, Self::Error> {
        TryInto::<u8>::try_into(value)
            .map_err(|_| crate::errors::EnumError::new(NAME, value.into()))?
            .try_into()
    }
}

impl TryFrom<i64> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: i64) -> Result<Self, Self::Error> {
        TryInto::<u8>::try_into(value)
            .map_err(|_| crate::errors::EnumError::new(NAME, value.into()))?
            .try_into()
    }
}

impl TryFrom<usize> for TransferAbortReason {
    type Error = crate::errors::EnumError;
    fn try_from(value: usize) -> Result<Self, Self::Error> {
        TryInto::<u8>::try_into(value)
            .map_err(|_| crate::errors::EnumError::new(NAME, value as i128))?
            .try_into()
    }
}