Make LearnableMoves a trait
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				continuous-integration/drone/push Build is passing
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	continuous-integration/drone/push Build is passing
				
			This commit is contained in:
		| @@ -23,7 +23,7 @@ unsafe extern "C" fn form_new( | ||||
|     abilities_length: usize, | ||||
|     hidden_abilities: *const BorrowedPtr<c_char>, | ||||
|     hidden_abilities_length: usize, | ||||
|     moves: OwnedPtr<LearnableMoves>, | ||||
|     moves: OwnedPtr<Box<dyn LearnableMoves>>, | ||||
|     flags: *const *const c_char, | ||||
|     flags_length: usize, | ||||
| ) -> IdentifiablePointer<Arc<Form>> { | ||||
| @@ -89,7 +89,11 @@ unsafe extern "C" fn form_base_stats(ptr: ExternPointer<Arc<Form>>) -> Identifia | ||||
| ffi_vec_stringkey_getters!(Form, abilities); | ||||
| ffi_vec_stringkey_getters!(Form, hidden_abilities); | ||||
|  | ||||
| ffi_arc_getter!(Form, moves, BorrowedPtr<LearnableMoves>); | ||||
| /// The moves a Pokemon with this form can learn. | ||||
| #[no_mangle] | ||||
| extern "C" fn form_moves(ptr: ExternPointer<Arc<Form>>) -> BorrowedPtr<Box<dyn LearnableMoves>> { | ||||
|     ptr.as_ref().moves() as *const Box<dyn LearnableMoves> | ||||
| } | ||||
|  | ||||
| /// Check if the form has a specific flag set. | ||||
| #[no_mangle] | ||||
|   | ||||
| @@ -1,25 +1,25 @@ | ||||
| use crate::defines::LevelInt; | ||||
| use crate::ffi::{BorrowedPtr, ExternPointer, OwnedPtr}; | ||||
| use crate::static_data::LearnableMoves; | ||||
| use crate::static_data::{LearnableMoves, LearnableMovesImpl}; | ||||
| use std::ffi::{c_char, CStr}; | ||||
| use std::ptr::drop_in_place; | ||||
|  | ||||
| /// Instantiates a new Learnable Moves. | ||||
| #[no_mangle] | ||||
| extern "C" fn learnable_moves_new() -> OwnedPtr<LearnableMoves> { | ||||
|     Box::into_raw(Box::new(LearnableMoves::new())) | ||||
| extern "C" fn learnable_moves_new() -> OwnedPtr<Box<dyn LearnableMoves>> { | ||||
|     Box::into_raw(Box::new(Box::new(LearnableMovesImpl::new()))) | ||||
| } | ||||
|  | ||||
| /// drops a learnablemoves struct. | ||||
| #[no_mangle] | ||||
| unsafe extern "C" fn learnable_moves_drop(ptr: OwnedPtr<LearnableMoves>) { | ||||
| unsafe extern "C" fn learnable_moves_drop(ptr: OwnedPtr<Box<dyn LearnableMoves>>) { | ||||
|     drop_in_place(ptr) | ||||
| } | ||||
|  | ||||
| /// Adds a new level move the Pokemon can learn. | ||||
| #[no_mangle] | ||||
| unsafe extern "C" fn learnable_moves_add_level_move( | ||||
|     mut ptr: ExternPointer<LearnableMoves>, | ||||
|     mut ptr: ExternPointer<Box<dyn LearnableMoves>>, | ||||
|     level: LevelInt, | ||||
|     move_name: BorrowedPtr<c_char>, | ||||
| ) { | ||||
|   | ||||
| @@ -48,10 +48,9 @@ pub mod tests { | ||||
|  | ||||
|     use crate::static_data::libraries::data_library::DataLibrary; | ||||
|     use crate::static_data::libraries::species_library::SpeciesLibrary; | ||||
|     use crate::static_data::Form; | ||||
|     use crate::static_data::LearnableMoves; | ||||
|     use crate::static_data::Species; | ||||
|     use crate::static_data::StaticStatisticSet; | ||||
|     use crate::static_data::{Form, LearnableMovesImpl}; | ||||
|  | ||||
|     fn build_species() -> Species { | ||||
|         Species::new( | ||||
| @@ -69,7 +68,7 @@ pub mod tests { | ||||
|                 StaticStatisticSet::new(10, 10, 10, 10, 10, 10), | ||||
|                 Vec::new(), | ||||
|                 Vec::new(), | ||||
|                 LearnableMoves::new(), | ||||
|                 Box::new(LearnableMovesImpl::new()), | ||||
|                 HashSet::new(), | ||||
|             )), | ||||
|             HashSet::new(), | ||||
|   | ||||
| @@ -30,7 +30,7 @@ pub struct Form { | ||||
|     /// The possible hidden abilities a Pokemon with this form can have. | ||||
|     hidden_abilities: Vec<StringKey>, | ||||
|     /// The moves a Pokemon with this form can learn. | ||||
|     moves: LearnableMoves, | ||||
|     moves: Box<dyn LearnableMoves>, | ||||
|     /// Arbitrary flags can be set on a form for scripting use. | ||||
|     flags: HashSet<StringKey>, | ||||
| } | ||||
| @@ -46,7 +46,7 @@ impl Form { | ||||
|         base_stats: StaticStatisticSet<u16>, | ||||
|         abilities: Vec<StringKey>, | ||||
|         hidden_abilities: Vec<StringKey>, | ||||
|         moves: LearnableMoves, | ||||
|         moves: Box<dyn LearnableMoves>, | ||||
|         flags: HashSet<StringKey>, | ||||
|     ) -> Form { | ||||
|         Form { | ||||
| @@ -96,8 +96,10 @@ impl Form { | ||||
|     pub fn hidden_abilities(&self) -> &Vec<StringKey> { | ||||
|         &self.hidden_abilities | ||||
|     } | ||||
|  | ||||
|     #[allow(clippy::borrowed_box)] | ||||
|     /// The moves a Pokemon with this form can learn. | ||||
|     pub fn moves(&self) -> &LearnableMoves { | ||||
|     pub fn moves(&self) -> &Box<dyn LearnableMoves> { | ||||
|         &self.moves | ||||
|     } | ||||
|     /// Arbitrary flags can be set on a form for scripting use. | ||||
|   | ||||
| @@ -1,26 +1,39 @@ | ||||
| use hashbrown::hash_map::Entry::{Occupied, Vacant}; | ||||
| use hashbrown::HashMap; | ||||
| use std::fmt::Debug; | ||||
|  | ||||
| use crate::defines::LevelInt; | ||||
| use crate::StringKey; | ||||
|  | ||||
| /// This allows for storage of the moves a Pokemon can learn. | ||||
| /// The storage of the moves a Pokemon can learn. | ||||
| pub trait LearnableMoves: Debug { | ||||
|     /// Adds a new level move the Pokemon can learn. | ||||
|     fn add_level_move(&mut self, level: LevelInt, m: &StringKey); | ||||
|     /// Gets all moves a Pokemon can learn when leveling up to a specific level. | ||||
|     fn get_learned_by_level(&self, level: LevelInt) -> Option<&Vec<StringKey>>; | ||||
|     /// Gets the distinct moves a Pokemon can learn through leveling up. | ||||
|     fn get_distinct_level_moves(&self) -> &Vec<StringKey>; | ||||
| } | ||||
|  | ||||
| /// The storage of the moves a Pokemon can learn. | ||||
| #[derive(Default, PartialEq, Eq, Debug)] | ||||
| pub struct LearnableMoves { | ||||
| pub struct LearnableMovesImpl { | ||||
|     /// A map of the moves a Pokemon can learn per level. | ||||
|     learned_by_level: HashMap<LevelInt, Vec<StringKey>>, | ||||
|     /// A list of the distinct moves a Pokemon can learn through leveling up. | ||||
|     distinct_level_moves: Vec<StringKey>, | ||||
| } | ||||
|  | ||||
| impl LearnableMoves { | ||||
| impl LearnableMovesImpl { | ||||
|     /// Instantiates a new Learnable Moves. | ||||
|     pub fn new() -> LearnableMoves { | ||||
|         LearnableMoves::default() | ||||
|     pub fn new() -> Self { | ||||
|         Self::default() | ||||
|     } | ||||
| } | ||||
|  | ||||
| impl LearnableMoves for LearnableMovesImpl { | ||||
|     /// Adds a new level move the Pokemon can learn. | ||||
|     pub fn add_level_move(&mut self, level: LevelInt, m: &StringKey) { | ||||
|     fn add_level_move(&mut self, level: LevelInt, m: &StringKey) { | ||||
|         match self.learned_by_level.entry(level) { | ||||
|             Occupied(x) => { | ||||
|                 x.into_mut().push(m.clone()); | ||||
| @@ -35,12 +48,12 @@ impl LearnableMoves { | ||||
|     } | ||||
|  | ||||
|     /// Gets all moves a Pokemon can learn when leveling up to a specific level. | ||||
|     pub fn get_learned_by_level(&self, level: LevelInt) -> Option<&Vec<StringKey>> { | ||||
|     fn get_learned_by_level(&self, level: LevelInt) -> Option<&Vec<StringKey>> { | ||||
|         self.learned_by_level.get(&level) | ||||
|     } | ||||
|  | ||||
|     /// Gets the distinct moves a Pokemon can learn through leveling up. | ||||
|     pub fn get_distinct_level_moves(&self) -> &Vec<StringKey> { | ||||
|     fn get_distinct_level_moves(&self) -> &Vec<StringKey> { | ||||
|         &self.distinct_level_moves | ||||
|     } | ||||
| } | ||||
| @@ -48,10 +61,11 @@ impl LearnableMoves { | ||||
| #[cfg(test)] | ||||
| mod tests { | ||||
|     use crate::static_data::species_data::learnable_moves::LearnableMoves; | ||||
|     use crate::static_data::LearnableMovesImpl; | ||||
|  | ||||
|     #[test] | ||||
|     fn adds_level_moves() { | ||||
|         let mut moves = LearnableMoves::new(); | ||||
|         let mut moves = LearnableMovesImpl::new(); | ||||
|         moves.add_level_move(1, &"foo".into()); | ||||
|         moves.add_level_move(1, &"bar".into()); | ||||
|  | ||||
| @@ -63,7 +77,7 @@ mod tests { | ||||
|  | ||||
|     #[test] | ||||
|     fn adds_two_same_moves_at_different_level() { | ||||
|         let mut moves = LearnableMoves::new(); | ||||
|         let mut moves = LearnableMovesImpl::new(); | ||||
|  | ||||
|         moves.add_level_move(1, &"foo".into()); | ||||
|         moves.add_level_move(5, &"foo".into()); | ||||
|   | ||||
| @@ -17,9 +17,9 @@ use pkmn_lib::dynamic_data::Gen7MiscLibrary; | ||||
| use pkmn_lib::script_implementations::wasm::script_resolver::WebAssemblyScriptResolver; | ||||
| use pkmn_lib::static_data::{ | ||||
|     AbilityImpl, AbilityLibrary, BattleItemCategory, DataLibrary, EffectParameter, Form, GrowthRateLibrary, ItemImpl, | ||||
|     ItemLibrary, LearnableMoves, LibrarySettings, LookupGrowthRate, MoveDataImpl, MoveLibrary, NatureImpl, | ||||
|     NatureLibrary, SecondaryEffect, SecondaryEffectImpl, Species, StaticData, StaticStatisticSet, Statistic, | ||||
|     TypeLibrary, | ||||
|     ItemLibrary, LearnableMoves, LearnableMovesImpl, LibrarySettings, LookupGrowthRate, MoveDataImpl, MoveLibrary, | ||||
|     NatureImpl, NatureLibrary, SecondaryEffect, SecondaryEffectImpl, Species, StaticData, StaticStatisticSet, | ||||
|     Statistic, TypeLibrary, | ||||
| }; | ||||
| use pkmn_lib::StringKey; | ||||
|  | ||||
| @@ -368,8 +368,8 @@ where | ||||
|     ) | ||||
| } | ||||
|  | ||||
| fn parse_moves(value: &Value, move_library: &MoveLibrary) -> LearnableMoves { | ||||
|     let mut moves = LearnableMoves::default(); | ||||
| fn parse_moves(value: &Value, move_library: &MoveLibrary) -> Box<dyn LearnableMoves> { | ||||
|     let mut moves = LearnableMovesImpl::default(); | ||||
|  | ||||
|     let level_moves = value.get("levelMoves").unwrap().as_array().unwrap(); | ||||
|     for level_move in level_moves { | ||||
| @@ -379,7 +379,7 @@ fn parse_moves(value: &Value, move_library: &MoveLibrary) -> LearnableMoves { | ||||
|         moves.add_level_move(level, &name); | ||||
|     } | ||||
|  | ||||
|     moves | ||||
|     Box::new(moves) | ||||
| } | ||||
|  | ||||
| fn parse_effect_parameter(value: &Value) -> EffectParameter { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user