use crate::Error;
use crate::Connector;
use crate::net::Packet;
use crate::net::BinaryReader;
use crate::unit::Corona;
use crate::unit::any_unit::prelude::*;
pub struct Sun {
unit: UnitData,
coronas: Vec<Corona>
}
impl Sun {
pub fn from_reader(connector: &Arc<Connector>, universe_group: &UniverseGroup, packet: &Packet, reader: &mut BinaryReader) -> Result<Sun, Error> {
let unit = UnitData::from_reader(connector, universe_group, packet, reader)?;
let count = reader.read_unsigned_byte()?;
let mut coronas = Vec::with_capacity(count as usize);
for _ in 0..count {
coronas.push(Corona::from_reader(reader)?);
}
Ok(Sun {
unit,
coronas
})
}
pub fn coronas(&self) -> &Vec<Corona> {
&self.coronas
}
}
impl Unit for Sun {
fn name(&self) -> &str {
self.unit.name()
}
fn position(&self) -> &Vector {
self.unit.position()
}
fn movement(&self) -> &Vector {
self.unit.movement()
}
fn radius(&self) -> f32 {
self.unit.radius()
}
fn gravity(&self) -> f32 {
self.unit.gravity()
}
fn team(&self) -> &Weak<Team> {
self.unit.team()
}
fn is_solid(&self) -> bool {
self.unit.is_solid()
}
fn is_masking(&self) -> bool {
self.unit.is_masking()
}
fn is_visible(&self) -> bool {
self.unit.is_visible()
}
fn is_orbiting(&self) -> bool {
self.unit.is_orbiting()
}
fn orbiting_center(&self) -> &Option<Vector> {
self.unit.orbiting_center()
}
fn orbiting_states(&self) -> &Option<Vec<OrbitingState>> {
self.unit.orbiting_states()
}
fn mobility(&self) -> Mobility {
self.unit.mobility()
}
fn connector(&self) -> &Weak<Connector> {
self.unit.connector()
}
fn kind(&self) -> UnitKind {
UnitKind::Sun
}
}