mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Merge branch 'make_crustaceans_tameable' into 'master'
make_crustaceans_tameable See merge request veloren/veloren!4219
This commit is contained in:
commit
c3db45541c
@ -1,11 +1,16 @@
|
||||
use crate::{make_case_elim, make_proj_elim};
|
||||
use rand::{seq::SliceRandom, thread_rng};
|
||||
use serde::{Deserialize, Serialize};
|
||||
use strum::{Display, EnumString};
|
||||
|
||||
make_proj_elim!(
|
||||
body,
|
||||
#[derive(Copy, Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash, Serialize, Deserialize)]
|
||||
pub struct Body {
|
||||
pub species: Species,
|
||||
pub body_type: BodyType,
|
||||
}
|
||||
);
|
||||
|
||||
impl Body {
|
||||
pub fn random() -> Self {
|
||||
@ -25,11 +30,29 @@ impl From<Body> for super::Body {
|
||||
fn from(body: Body) -> Self { super::Body::Crustacean(body) }
|
||||
}
|
||||
|
||||
#[derive(Copy, Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash, Serialize, Deserialize)]
|
||||
// Renaming any enum entries here (re-ordering is fine) will require a
|
||||
// database migration to ensure pets correctly de-serialize on player login.
|
||||
make_case_elim!(
|
||||
species,
|
||||
#[derive(
|
||||
Copy,
|
||||
Clone,
|
||||
Debug,
|
||||
Display,
|
||||
EnumString,
|
||||
PartialEq,
|
||||
Eq,
|
||||
PartialOrd,
|
||||
Ord,
|
||||
Hash,
|
||||
Serialize,
|
||||
Deserialize,
|
||||
)]
|
||||
#[repr(u32)]
|
||||
pub enum Species {
|
||||
Crab = 0,
|
||||
}
|
||||
);
|
||||
|
||||
/// Data representing per-species generic data.
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
@ -57,10 +80,26 @@ impl<'a, SpeciesMeta: 'a> IntoIterator for &'a AllSpecies<SpeciesMeta> {
|
||||
fn into_iter(self) -> Self::IntoIter { ALL_SPECIES.iter().copied() }
|
||||
}
|
||||
|
||||
#[derive(Copy, Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash, Serialize, Deserialize)]
|
||||
make_case_elim!(
|
||||
body_type,
|
||||
#[derive(
|
||||
Copy,
|
||||
Clone,
|
||||
Debug,
|
||||
Display,
|
||||
EnumString,
|
||||
PartialEq,
|
||||
Eq,
|
||||
PartialOrd,
|
||||
Ord,
|
||||
Hash,
|
||||
Serialize,
|
||||
Deserialize,
|
||||
)]
|
||||
#[repr(u32)]
|
||||
pub enum BodyType {
|
||||
Female = 0,
|
||||
Male = 1,
|
||||
}
|
||||
);
|
||||
pub const ALL_BODY_TYPES: [BodyType; 2] = [BodyType::Female, BodyType::Male];
|
||||
|
@ -52,7 +52,10 @@ pub fn is_tameable(body: &Body) -> bool {
|
||||
| quadruped_medium::Species::Hirdrasil
|
||||
)
|
||||
},
|
||||
Body::QuadrupedLow(_) | Body::QuadrupedSmall(_) | Body::BirdMedium(_) => true,
|
||||
Body::QuadrupedLow(_)
|
||||
| Body::QuadrupedSmall(_)
|
||||
| Body::BirdMedium(_)
|
||||
| Body::Crustacean(_) => true,
|
||||
_ => false,
|
||||
}
|
||||
}
|
||||
|
@ -220,6 +220,10 @@ pub fn convert_body_to_database_json(
|
||||
"bird_medium",
|
||||
serde_json::to_string(&GenericBody::from(body))?,
|
||||
),
|
||||
Body::Crustacean(body) => (
|
||||
"crustacean",
|
||||
serde_json::to_string(&GenericBody::from(body))?,
|
||||
),
|
||||
_ => {
|
||||
return Err(PersistenceError::ConversionError(format!(
|
||||
"Unsupported body type for persistence: {:?}",
|
||||
@ -597,6 +601,9 @@ pub fn convert_body_from_database(
|
||||
"bird_medium" => {
|
||||
deserialize_body!(body_data, BirdMedium, bird_medium)
|
||||
},
|
||||
"crustacean" => {
|
||||
deserialize_body!(body_data, Crustacean, crustacean)
|
||||
},
|
||||
_ => {
|
||||
return Err(PersistenceError::ConversionError(format!(
|
||||
"{} is not a supported body type for deserialization",
|
||||
|
@ -60,6 +60,7 @@ generic_body_from_impl!(comp::quadruped_low::Body);
|
||||
generic_body_from_impl!(comp::quadruped_medium::Body);
|
||||
generic_body_from_impl!(comp::quadruped_small::Body);
|
||||
generic_body_from_impl!(comp::bird_medium::Body);
|
||||
generic_body_from_impl!(comp::crustacean::Body);
|
||||
|
||||
#[derive(Serialize, Deserialize)]
|
||||
pub struct CharacterPosition {
|
||||
|
Loading…
Reference in New Issue
Block a user