mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
78 lines
2.4 KiB
Rust
78 lines
2.4 KiB
Rust
|
use crate::client::Client;
|
||
|
use common::{
|
||
|
comp::{anchor::Anchor, group::GroupManager, Agent, Alignment, Pet},
|
||
|
uid::Uid,
|
||
|
};
|
||
|
use common_net::msg::ServerGeneral;
|
||
|
use specs::{Entity, WorldExt};
|
||
|
use tracing::warn;
|
||
|
|
||
|
/// Restores a pet retrieved from the database on login, assigning it to its
|
||
|
/// owner
|
||
|
pub fn restore_pet(ecs: &specs::World, pet_entity: Entity, owner: Entity, pet: Pet) {
|
||
|
tame_pet_internal(ecs, pet_entity, owner, Some(pet));
|
||
|
}
|
||
|
|
||
|
/// Tames a pet, adding to the owner's group and setting its alignment
|
||
|
pub fn tame_pet(ecs: &specs::World, pet_entity: Entity, owner: Entity) {
|
||
|
tame_pet_internal(ecs, pet_entity, owner, None);
|
||
|
}
|
||
|
|
||
|
fn tame_pet_internal(ecs: &specs::World, pet_entity: Entity, owner: Entity, pet: Option<Pet>) {
|
||
|
let uids = ecs.read_storage::<Uid>();
|
||
|
let owner_uid = match uids.get(owner) {
|
||
|
Some(uid) => *uid,
|
||
|
None => return,
|
||
|
};
|
||
|
|
||
|
if let Some(Alignment::Owned(existing_owner_uid)) =
|
||
|
ecs.read_storage::<Alignment>().get(pet_entity)
|
||
|
{
|
||
|
if *existing_owner_uid != owner_uid {
|
||
|
warn!("Disallowing taming of pet already owned by another entity");
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
let _ = ecs
|
||
|
.write_storage()
|
||
|
.insert(pet_entity, common::comp::Alignment::Owned(owner_uid));
|
||
|
|
||
|
// Anchor the pet to the player to prevent it de-spawning
|
||
|
// when its chunk is unloaded if its owner is still logged
|
||
|
// in
|
||
|
let _ = ecs
|
||
|
.write_storage()
|
||
|
.insert(pet_entity, Anchor::Entity(owner));
|
||
|
|
||
|
let _ = ecs
|
||
|
.write_storage()
|
||
|
.insert(pet_entity, pet.unwrap_or_default());
|
||
|
|
||
|
// TODO: Review whether we should be doing this or not, should the Agent always
|
||
|
// be overwritten when taming a pet?
|
||
|
let _ = ecs.write_storage().insert(pet_entity, Agent::default());
|
||
|
|
||
|
// Add to group system
|
||
|
let clients = ecs.read_storage::<Client>();
|
||
|
let mut group_manager = ecs.write_resource::<GroupManager>();
|
||
|
group_manager.new_pet(
|
||
|
pet_entity,
|
||
|
owner,
|
||
|
&mut ecs.write_storage(),
|
||
|
&ecs.entities(),
|
||
|
&ecs.read_storage(),
|
||
|
&uids,
|
||
|
&mut |entity, group_change| {
|
||
|
clients
|
||
|
.get(entity)
|
||
|
.and_then(|c| {
|
||
|
group_change
|
||
|
.try_map(|e| uids.get(e).copied())
|
||
|
.map(|g| (g, c))
|
||
|
})
|
||
|
.map(|(g, c)| c.send_fallible(ServerGeneral::GroupUpdate(g)));
|
||
|
},
|
||
|
);
|
||
|
}
|