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