This commit is contained in:
		| @@ -6,7 +6,7 @@ use hashbrown::HashSet; | |||||||
| use crate::dynamic_data::choices::{MoveChoice, TurnChoice}; | use crate::dynamic_data::choices::{MoveChoice, TurnChoice}; | ||||||
| use crate::dynamic_data::Pokemon; | use crate::dynamic_data::Pokemon; | ||||||
| use crate::dynamic_data::{LearnedMove, MoveLearnMethod}; | use crate::dynamic_data::{LearnedMove, MoveLearnMethod}; | ||||||
| use crate::static_data::{MoveCategory, MoveData, MoveTarget, SecondaryEffectImpl}; | use crate::static_data::{MoveCategory, MoveData, MoveDataImpl, MoveTarget, SecondaryEffectImpl}; | ||||||
| use crate::{StringKey, ValueIdentifiable, ValueIdentifier}; | use crate::{StringKey, ValueIdentifiable, ValueIdentifier}; | ||||||
|  |  | ||||||
| /// The misc library holds several misc functions required for the battle to run. | /// The misc library holds several misc functions required for the battle to run. | ||||||
| @@ -31,7 +31,7 @@ pub struct Gen7MiscLibrary { | |||||||
| impl Gen7MiscLibrary { | impl Gen7MiscLibrary { | ||||||
|     /// Instantiates a new MiscLibrary. |     /// Instantiates a new MiscLibrary. | ||||||
|     pub fn new() -> Self { |     pub fn new() -> Self { | ||||||
|         let struggle_data = Arc::new(MoveData::new( |         let struggle_data: Arc<dyn MoveData> = Arc::new(MoveDataImpl::new( | ||||||
|             &StringKey::new("struggle"), |             &StringKey::new("struggle"), | ||||||
|             0.into(), |             0.into(), | ||||||
|             MoveCategory::Physical, |             MoveCategory::Physical, | ||||||
|   | |||||||
| @@ -101,7 +101,7 @@ pub struct ExecutingMove { | |||||||
|     /// The move the user has actually chosen to do. |     /// The move the user has actually chosen to do. | ||||||
|     chosen_move: Arc<LearnedMove>, |     chosen_move: Arc<LearnedMove>, | ||||||
|     /// The move that the user is actually going to do. |     /// The move that the user is actually going to do. | ||||||
|     use_move: Arc<MoveData>, |     use_move: Arc<dyn MoveData>, | ||||||
|     /// The script of the move. |     /// The script of the move. | ||||||
|     script: ScriptContainer, |     script: ScriptContainer, | ||||||
|     /// The targets for this move. |     /// The targets for this move. | ||||||
| @@ -117,7 +117,7 @@ impl ExecutingMove { | |||||||
|         number_of_hits: u8, |         number_of_hits: u8, | ||||||
|         user: Arc<Pokemon>, |         user: Arc<Pokemon>, | ||||||
|         chosen_move: Arc<LearnedMove>, |         chosen_move: Arc<LearnedMove>, | ||||||
|         use_move: Arc<MoveData>, |         use_move: Arc<dyn MoveData>, | ||||||
|         script: ScriptContainer, |         script: ScriptContainer, | ||||||
|     ) -> Self { |     ) -> Self { | ||||||
|         let total_hits = number_of_hits as usize * targets.len(); |         let total_hits = number_of_hits as usize * targets.len(); | ||||||
| @@ -155,7 +155,7 @@ impl ExecutingMove { | |||||||
|         &self.chosen_move |         &self.chosen_move | ||||||
|     } |     } | ||||||
|     /// The move that the user is actually going to do. |     /// The move that the user is actually going to do. | ||||||
|     pub fn use_move(&self) -> &Arc<MoveData> { |     pub fn use_move(&self) -> &Arc<dyn MoveData> { | ||||||
|         &self.use_move |         &self.use_move | ||||||
|     } |     } | ||||||
|     /// The script of the move. |     /// The script of the move. | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ pub struct LearnedMove { | |||||||
|     /// A unique identifier so we know what value this is. |     /// A unique identifier so we know what value this is. | ||||||
|     identifier: ValueIdentifier, |     identifier: ValueIdentifier, | ||||||
|     /// The immutable move information of the move. |     /// The immutable move information of the move. | ||||||
|     move_data: Arc<MoveData>, |     move_data: Arc<dyn MoveData>, | ||||||
|     /// The maximal power points for this move. |     /// The maximal power points for this move. | ||||||
|     max_pp: u8, |     max_pp: u8, | ||||||
|     /// The amount of remaining power points. If this is 0, we can not use the move anymore. |     /// The amount of remaining power points. If this is 0, we can not use the move anymore. | ||||||
| @@ -33,7 +33,7 @@ pub enum MoveLearnMethod { | |||||||
|  |  | ||||||
| impl LearnedMove { | impl LearnedMove { | ||||||
|     /// Instantiate a new learned move. |     /// Instantiate a new learned move. | ||||||
|     pub fn new(move_data: &Arc<MoveData>, learn_method: MoveLearnMethod) -> Self { |     pub fn new(move_data: &Arc<dyn MoveData>, learn_method: MoveLearnMethod) -> Self { | ||||||
|         Self { |         Self { | ||||||
|             identifier: Default::default(), |             identifier: Default::default(), | ||||||
|             move_data: move_data.clone(), |             move_data: move_data.clone(), | ||||||
| @@ -44,7 +44,7 @@ impl LearnedMove { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /// The immutable move information of the move. |     /// The immutable move information of the move. | ||||||
|     pub fn move_data(&self) -> &Arc<MoveData> { |     pub fn move_data(&self) -> &Arc<dyn MoveData> { | ||||||
|         &self.move_data |         &self.move_data | ||||||
|     } |     } | ||||||
|     /// The maximal power points for this move. |     /// The maximal power points for this move. | ||||||
| @@ -100,11 +100,11 @@ impl ValueIdentifiable for LearnedMove { | |||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
| mod tests { | mod tests { | ||||||
|     use super::*; |     use super::*; | ||||||
|     use crate::static_data::{MoveCategory, MoveTarget}; |     use crate::static_data::{MoveCategory, MoveDataImpl, MoveTarget}; | ||||||
|  |  | ||||||
|     #[test] |     #[test] | ||||||
|     fn create_learned_move_restore_uses() { |     fn create_learned_move_restore_uses() { | ||||||
|         let data = Arc::new(MoveData::new( |         let data: Arc<dyn MoveData> = Arc::new(MoveDataImpl::new( | ||||||
|             &"foo".into(), |             &"foo".into(), | ||||||
|             0u8.into(), |             0u8.into(), | ||||||
|             MoveCategory::Special, |             MoveCategory::Special, | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ use std::sync::Arc; | |||||||
| /// Instantiate a new learned move. | /// Instantiate a new learned move. | ||||||
| #[no_mangle] | #[no_mangle] | ||||||
| extern "C" fn learned_move_new( | extern "C" fn learned_move_new( | ||||||
|     move_data: ExternPointer<Arc<MoveData>>, |     move_data: ExternPointer<Arc<dyn MoveData>>, | ||||||
|     learn_method: MoveLearnMethod, |     learn_method: MoveLearnMethod, | ||||||
| ) -> IdentifiablePointer<Arc<LearnedMove>> { | ) -> IdentifiablePointer<Arc<LearnedMove>> { | ||||||
|     Arc::new(LearnedMove::new(move_data.as_ref(), learn_method)).into() |     Arc::new(LearnedMove::new(move_data.as_ref(), learn_method)).into() | ||||||
| @@ -23,7 +23,7 @@ extern "C" fn learned_move_drop(learned_move: OwnedPtr<Arc<LearnedMove>>) { | |||||||
| #[no_mangle] | #[no_mangle] | ||||||
| extern "C" fn learned_move_move_data( | extern "C" fn learned_move_move_data( | ||||||
|     learned_move: ExternPointer<Arc<LearnedMove>>, |     learned_move: ExternPointer<Arc<LearnedMove>>, | ||||||
| ) -> IdentifiablePointer<Arc<MoveData>> { | ) -> IdentifiablePointer<Arc<dyn MoveData>> { | ||||||
|     learned_move.as_ref().move_data().clone().into() |     learned_move.as_ref().move_data().clone().into() | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -73,6 +73,6 @@ macro_rules! library_interface { | |||||||
| } | } | ||||||
|  |  | ||||||
| library_interface!(SpeciesLibrary, Species); | library_interface!(SpeciesLibrary, Species); | ||||||
| library_interface!(MoveLibrary, MoveData); | library_interface!(MoveLibrary, dyn MoveData); | ||||||
| library_interface!(AbilityLibrary, dyn Ability); | library_interface!(AbilityLibrary, dyn Ability); | ||||||
| library_interface!(ItemLibrary, dyn Item); | library_interface!(ItemLibrary, dyn Item); | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| use crate::ffi::{ffi_arc_getter, BorrowedPtr, ExternPointer, IdentifiablePointer, OwnedPtr}; | use crate::ffi::{ffi_arc_getter, BorrowedPtr, ExternPointer, IdentifiablePointer, OwnedPtr}; | ||||||
| use crate::static_data::{ | use crate::static_data::{ | ||||||
|     EffectParameter, MoveCategory, MoveData, MoveTarget, SecondaryEffect, SecondaryEffectImpl, TypeIdentifier, |     EffectParameter, MoveCategory, MoveData, MoveDataImpl, MoveTarget, SecondaryEffect, SecondaryEffectImpl, | ||||||
|  |     TypeIdentifier, | ||||||
| }; | }; | ||||||
| use crate::StringKey; | use crate::StringKey; | ||||||
| use hashbrown::HashSet; | use hashbrown::HashSet; | ||||||
| @@ -22,7 +23,7 @@ unsafe extern "C" fn move_data_new( | |||||||
|     secondary_effect: *mut Box<dyn SecondaryEffect>, |     secondary_effect: *mut Box<dyn SecondaryEffect>, | ||||||
|     flags: *const *const c_char, |     flags: *const *const c_char, | ||||||
|     flags_length: usize, |     flags_length: usize, | ||||||
| ) -> IdentifiablePointer<Arc<MoveData>> { | ) -> IdentifiablePointer<Arc<dyn MoveData>> { | ||||||
|     let flags = std::slice::from_raw_parts(flags, flags_length); |     let flags = std::slice::from_raw_parts(flags, flags_length); | ||||||
|     let name: StringKey = CStr::from_ptr(name).to_str().unwrap().into(); |     let name: StringKey = CStr::from_ptr(name).to_str().unwrap().into(); | ||||||
|     let mut flags_set: HashSet<StringKey> = HashSet::with_capacity(flags_length); |     let mut flags_set: HashSet<StringKey> = HashSet::with_capacity(flags_length); | ||||||
| @@ -34,7 +35,7 @@ unsafe extern "C" fn move_data_new( | |||||||
|     } else { |     } else { | ||||||
|         Some(*Box::from_raw(secondary_effect)) |         Some(*Box::from_raw(secondary_effect)) | ||||||
|     }; |     }; | ||||||
|     Arc::new(MoveData::new( |     let a: Arc<dyn MoveData> = Arc::new(MoveDataImpl::new( | ||||||
|         &name, |         &name, | ||||||
|         move_type, |         move_type, | ||||||
|         category, |         category, | ||||||
| @@ -45,42 +46,42 @@ unsafe extern "C" fn move_data_new( | |||||||
|         priority, |         priority, | ||||||
|         secondary_effect, |         secondary_effect, | ||||||
|         flags_set, |         flags_set, | ||||||
|     )) |     )); | ||||||
|     .into() |     a.into() | ||||||
| } | } | ||||||
|  |  | ||||||
| /// Drops a reference counted move. | /// Drops a reference counted move. | ||||||
| #[no_mangle] | #[no_mangle] | ||||||
| unsafe extern "C" fn move_data_drop(ptr: OwnedPtr<Arc<MoveData>>) { | unsafe extern "C" fn move_data_drop(ptr: OwnedPtr<Arc<dyn MoveData>>) { | ||||||
|     drop_in_place(ptr) |     drop_in_place(ptr) | ||||||
| } | } | ||||||
|  |  | ||||||
| /// The name of the move. | /// The name of the move. | ||||||
| #[no_mangle] | #[no_mangle] | ||||||
| unsafe extern "C" fn move_data_name(ptr: ExternPointer<Arc<MoveData>>) -> OwnedPtr<c_char> { | unsafe extern "C" fn move_data_name(ptr: ExternPointer<Arc<dyn MoveData>>) -> OwnedPtr<c_char> { | ||||||
|     let name = ptr.as_ref().name(); |     let name = ptr.as_ref().name(); | ||||||
|     CString::new(name.str()).unwrap().into_raw() |     CString::new(name.str()).unwrap().into_raw() | ||||||
| } | } | ||||||
|  |  | ||||||
| ffi_arc_getter!(MoveData, move_type, TypeIdentifier); | ffi_arc_getter!(dyn MoveData, move_type, TypeIdentifier); | ||||||
| ffi_arc_getter!(MoveData, category, MoveCategory); | ffi_arc_getter!(dyn MoveData, category, MoveCategory); | ||||||
| ffi_arc_getter!(MoveData, base_power, u8); | ffi_arc_getter!(dyn MoveData, base_power, u8); | ||||||
| ffi_arc_getter!(MoveData, accuracy, u8); | ffi_arc_getter!(dyn MoveData, accuracy, u8); | ||||||
| ffi_arc_getter!(MoveData, base_usages, u8); | ffi_arc_getter!(dyn MoveData, base_usages, u8); | ||||||
| ffi_arc_getter!(MoveData, target, MoveTarget); | ffi_arc_getter!(dyn MoveData, target, MoveTarget); | ||||||
| ffi_arc_getter!(MoveData, priority, i8); | ffi_arc_getter!(dyn MoveData, priority, i8); | ||||||
|  |  | ||||||
| /// The optional secondary effect the move has. | /// The optional secondary effect the move has. | ||||||
| #[no_mangle] | #[no_mangle] | ||||||
| unsafe extern "C" fn move_data_secondary_effect( | unsafe extern "C" fn move_data_secondary_effect( | ||||||
|     ptr: ExternPointer<Arc<MoveData>>, |     ptr: ExternPointer<Arc<dyn MoveData>>, | ||||||
| ) -> IdentifiablePointer<Box<dyn SecondaryEffect>> { | ) -> IdentifiablePointer<Box<dyn SecondaryEffect>> { | ||||||
|     ptr.as_ref().secondary_effect().into() |     ptr.as_ref().secondary_effect().into() | ||||||
| } | } | ||||||
|  |  | ||||||
| /// Arbitrary flags that can be applied to the move. | /// Arbitrary flags that can be applied to the move. | ||||||
| #[no_mangle] | #[no_mangle] | ||||||
| unsafe extern "C" fn move_data_has_flag(ptr: ExternPointer<Arc<MoveData>>, flag: *const c_char) -> u8 { | unsafe extern "C" fn move_data_has_flag(ptr: ExternPointer<Arc<dyn MoveData>>, flag: *const c_char) -> u8 { | ||||||
|     let flag = CStr::from_ptr(flag).into(); |     let flag = CStr::from_ptr(flag).into(); | ||||||
|     u8::from(ptr.as_ref().has_flag(&flag)) |     u8::from(ptr.as_ref().has_flag(&flag)) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -16,15 +16,15 @@ register! { | |||||||
|     fn executing_move_get_use_move( |     fn executing_move_get_use_move( | ||||||
|         env: FunctionEnvMut<WebAssemblyEnv>, |         env: FunctionEnvMut<WebAssemblyEnv>, | ||||||
|         executing_move: ExternRef<ExecutingMove>, |         executing_move: ExternRef<ExecutingMove>, | ||||||
|     ) -> ExternRef<MoveData> { |     ) -> ExternRef<dyn MoveData> { | ||||||
|         ExternRef::func_new(&env, executing_move.value_func(&env).unwrap().use_move().as_ref()) |         ExternRef::func_new(&env, executing_move.value_func(&env).unwrap().use_move()) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     fn executing_move_get_chosen_move( |     fn executing_move_get_chosen_move( | ||||||
|         env: FunctionEnvMut<WebAssemblyEnv>, |         env: FunctionEnvMut<WebAssemblyEnv>, | ||||||
|         executing_move: ExternRef<ExecutingMove>, |         executing_move: ExternRef<ExecutingMove>, | ||||||
|     ) -> ExternRef<LearnedMove> { |     ) -> ExternRef<LearnedMove> { | ||||||
|         ExternRef::func_new(&env, executing_move.value_func(&env).unwrap().chosen_move().as_ref()) |         ExternRef::func_new(&env, executing_move.value_func_arc(&env).unwrap().chosen_move().as_ref()) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     fn executing_move_get_number_of_hits( |     fn executing_move_get_number_of_hits( | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ register! { | |||||||
|     fn learned_move_get_move_data( |     fn learned_move_get_move_data( | ||||||
|         env: FunctionEnvMut<WebAssemblyEnv>, |         env: FunctionEnvMut<WebAssemblyEnv>, | ||||||
|         turn_choice: ExternRef<LearnedMove>, |         turn_choice: ExternRef<LearnedMove>, | ||||||
|     ) -> ExternRef<MoveData> { |     ) -> ExternRef<dyn MoveData> { | ||||||
|         ExternRef::func_new(&env, turn_choice.value_func(&env).unwrap().move_data()) |         ExternRef::func_new(&env, turn_choice.value_func(&env).unwrap().move_data()) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ fn move_library_get_move( | |||||||
|     env: FunctionEnvMut<WebAssemblyEnv>, |     env: FunctionEnvMut<WebAssemblyEnv>, | ||||||
|     lib: ExternRef<MoveLibrary>, |     lib: ExternRef<MoveLibrary>, | ||||||
|     string_key: ExternRef<StringKey>, |     string_key: ExternRef<StringKey>, | ||||||
| ) -> ExternRef<MoveData> { | ) -> ExternRef<dyn MoveData> { | ||||||
|     let lib = lib.value_func(&env).unwrap(); |     let lib = lib.value_func(&env).unwrap(); | ||||||
|     let m = lib.get(string_key.value_func(&env).unwrap()); |     let m = lib.get(string_key.value_func(&env).unwrap()); | ||||||
|     if let Some(v) = m { |     if let Some(v) = m { | ||||||
| @@ -20,7 +20,7 @@ fn move_library_get_move( | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| fn move_library_get_move_by_hash(env: FunctionEnvMut<WebAssemblyEnv>, lib: ExternRef<MoveLibrary>, hash: u32) -> ExternRef<MoveData> { | fn move_library_get_move_by_hash(env: FunctionEnvMut<WebAssemblyEnv>, lib: ExternRef<MoveLibrary>, hash: u32) -> ExternRef<dyn MoveData> { | ||||||
|     let lib = lib.value_func(&env).unwrap(); |     let lib = lib.value_func(&env).unwrap(); | ||||||
|     let m = lib.get_by_hash(hash); |     let m = lib.get_by_hash(hash); | ||||||
|     if let Some(v) = m { |     if let Some(v) = m { | ||||||
| @@ -30,35 +30,35 @@ fn move_library_get_move_by_hash(env: FunctionEnvMut<WebAssemblyEnv>, lib: Exter | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| fn move_data_get_name(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> ExternRef<StringKey> { | fn move_data_get_name(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> ExternRef<StringKey> { | ||||||
|     ExternRef::func_new(&env, move_data.value_func(&env).unwrap().name()) |     ExternRef::func_new(&env, move_data.value_func_arc(&env).unwrap().name()) | ||||||
| } | } | ||||||
|  |  | ||||||
| fn move_data_get_type(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> u8 { | fn move_data_get_type(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> u8 { | ||||||
|     move_data.value_func(&env).unwrap().move_type().into() |     move_data.value_func_arc(&env).unwrap().move_type().into() | ||||||
| } | } | ||||||
| fn move_data_get_category(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> u8 { | fn move_data_get_category(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> u8 { | ||||||
|     move_data.value_func(&env).unwrap().category() as u8 |     move_data.value_func_arc(&env).unwrap().category() as u8 | ||||||
| } | } | ||||||
| fn move_data_get_base_power(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> u8 { | fn move_data_get_base_power(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> u8 { | ||||||
|     move_data.value_func(&env).unwrap().base_power() |     move_data.value_func_arc(&env).unwrap().base_power() | ||||||
| } | } | ||||||
| fn move_data_get_accuracy(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> u8 { | fn move_data_get_accuracy(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> u8 { | ||||||
|     move_data.value_func(&env).unwrap().accuracy() |     move_data.value_func_arc(&env).unwrap().accuracy() | ||||||
| } | } | ||||||
| fn move_data_get_base_usages(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> u8 { | fn move_data_get_base_usages(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> u8 { | ||||||
|     move_data.value_func(&env).unwrap().base_usages() |     move_data.value_func_arc(&env).unwrap().base_usages() | ||||||
| } | } | ||||||
| fn move_data_get_target(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> u8 { | fn move_data_get_target(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> u8 { | ||||||
|     move_data.value_func(&env).unwrap().target() as u8 |     move_data.value_func_arc(&env).unwrap().target() as u8 | ||||||
| } | } | ||||||
| fn move_data_get_priority(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>) -> i8 { | fn move_data_get_priority(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>) -> i8 { | ||||||
|     move_data.value_func(&env).unwrap().priority() |     move_data.value_func_arc(&env).unwrap().priority() | ||||||
| } | } | ||||||
| fn move_data_has_flag(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>, flag: ExternRef<StringKey>) -> u8 { | fn move_data_has_flag(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>, flag: ExternRef<StringKey>) -> u8 { | ||||||
|     u8::from(move_data.value_func(&env).unwrap().has_flag(flag.value_func(&env).unwrap())) |     u8::from(move_data.value_func_arc(&env).unwrap().has_flag(flag.value_func(&env).unwrap())) | ||||||
| } | } | ||||||
| fn move_data_has_flag_by_hash(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<MoveData>, flag_hash: u32) -> u8 { | fn move_data_has_flag_by_hash(env: FunctionEnvMut<WebAssemblyEnv>, move_data: ExternRef<dyn MoveData>, flag_hash: u32) -> u8 { | ||||||
|     u8::from(move_data.value_func(&env).unwrap().has_flag_by_hash(flag_hash)) |     u8::from(move_data.value_func_arc(&env).unwrap().has_flag_by_hash(flag_hash)) | ||||||
| } | } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ pub struct MoveLibrary { | |||||||
|     /// A unique identifier so we know what value this is. |     /// A unique identifier so we know what value this is. | ||||||
|     identifier: ValueIdentifier, |     identifier: ValueIdentifier, | ||||||
|     /// The underlying map. |     /// The underlying map. | ||||||
|     map: IndexMap<StringKey, Arc<MoveData>>, |     map: IndexMap<StringKey, Arc<dyn MoveData>>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl MoveLibrary { | impl MoveLibrary { | ||||||
| @@ -26,11 +26,11 @@ impl MoveLibrary { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| impl DataLibrary<MoveData> for MoveLibrary { | impl DataLibrary<dyn MoveData> for MoveLibrary { | ||||||
|     fn map(&self) -> &IndexMap<StringKey, Arc<MoveData>> { |     fn map(&self) -> &IndexMap<StringKey, Arc<dyn MoveData>> { | ||||||
|         &self.map |         &self.map | ||||||
|     } |     } | ||||||
|     fn get_modify(&mut self) -> &mut IndexMap<StringKey, Arc<MoveData>> { |     fn get_modify(&mut self) -> &mut IndexMap<StringKey, Arc<dyn MoveData>> { | ||||||
|         &mut self.map |         &mut self.map | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -48,11 +48,11 @@ pub mod tests { | |||||||
|  |  | ||||||
|     use crate::static_data::libraries::data_library::DataLibrary; |     use crate::static_data::libraries::data_library::DataLibrary; | ||||||
|     use crate::static_data::libraries::move_library::MoveLibrary; |     use crate::static_data::libraries::move_library::MoveLibrary; | ||||||
|     use crate::static_data::{MoveCategory, MoveData, MoveTarget}; |     use crate::static_data::{MoveCategory, MoveDataImpl, MoveTarget}; | ||||||
|     use crate::StringKey; |     use crate::StringKey; | ||||||
|  |  | ||||||
|     fn build_move() -> MoveData { |     fn build_move() -> MoveDataImpl { | ||||||
|         MoveData::new( |         MoveDataImpl::new( | ||||||
|             &"foo".into(), |             &"foo".into(), | ||||||
|             0.into(), |             0.into(), | ||||||
|             MoveCategory::Physical, |             MoveCategory::Physical, | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| use hashbrown::HashSet; | use hashbrown::HashSet; | ||||||
| #[cfg(feature = "serde")] | #[cfg(feature = "serde")] | ||||||
| use serde::{Deserialize, Serialize}; | use serde::{Deserialize, Serialize}; | ||||||
|  | use std::fmt::Debug; | ||||||
|  |  | ||||||
| use crate::static_data::{SecondaryEffect, TypeIdentifier}; | use crate::static_data::{SecondaryEffect, TypeIdentifier}; | ||||||
| use crate::{StringKey, ValueIdentifiable, ValueIdentifier}; | use crate::{StringKey, ValueIdentifiable, ValueIdentifier}; | ||||||
| @@ -59,9 +60,40 @@ pub enum MoveTarget { | |||||||
|     SelfUse, |     SelfUse, | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /// A move is the skill Pokémon primarily use in battle. This is the data related to that. | ||||||
|  | pub trait MoveData: Debug + ValueIdentifiable { | ||||||
|  |     /// The name of the move. | ||||||
|  |     fn name(&self) -> &StringKey; | ||||||
|  |     /// The attacking type of the move. | ||||||
|  |     fn move_type(&self) -> TypeIdentifier; | ||||||
|  |     /// The category of the move. | ||||||
|  |     fn category(&self) -> MoveCategory; | ||||||
|  |     /// The base power, not considering any modifiers, the move has. | ||||||
|  |     fn base_power(&self) -> u8; | ||||||
|  |     /// The accuracy of the move in percentage. Should be 255 for moves that always hit. | ||||||
|  |     fn accuracy(&self) -> u8; | ||||||
|  |     /// The number of times the move can be used. This can be modified on actually learned moves using | ||||||
|  |     /// PP-Ups | ||||||
|  |     fn base_usages(&self) -> u8; | ||||||
|  |     /// How the move handles targets. | ||||||
|  |     fn target(&self) -> MoveTarget; | ||||||
|  |  | ||||||
|  |     /// The priority of the move. A higher priority means the move should go before other moves. | ||||||
|  |     fn priority(&self) -> i8; | ||||||
|  |  | ||||||
|  |     /// The optional secondary effect the move has. | ||||||
|  |     fn secondary_effect(&self) -> &Option<Box<dyn SecondaryEffect>>; | ||||||
|  |  | ||||||
|  |     /// Arbitrary flags that can be applied to the move. | ||||||
|  |     fn has_flag(&self, key: &StringKey) -> bool; | ||||||
|  |  | ||||||
|  |     /// Arbitrary flags that can be applied to the move. | ||||||
|  |     fn has_flag_by_hash(&self, key_hash: u32) -> bool; | ||||||
|  | } | ||||||
|  |  | ||||||
| /// A move is the skill Pokémon primarily use in battle. This is the data related to that. | /// A move is the skill Pokémon primarily use in battle. This is the data related to that. | ||||||
| #[derive(Debug)] | #[derive(Debug)] | ||||||
| pub struct MoveData { | pub struct MoveDataImpl { | ||||||
|     /// A unique identifier so we know what value this is. |     /// A unique identifier so we know what value this is. | ||||||
|     identifier: ValueIdentifier, |     identifier: ValueIdentifier, | ||||||
|     /// The name of the move. |     /// The name of the move. | ||||||
| @@ -87,7 +119,7 @@ pub struct MoveData { | |||||||
|     flags: HashSet<StringKey>, |     flags: HashSet<StringKey>, | ||||||
| } | } | ||||||
|  |  | ||||||
| impl MoveData { | impl MoveDataImpl { | ||||||
|     /// Instantiates a new move. |     /// Instantiates a new move. | ||||||
|     pub fn new( |     pub fn new( | ||||||
|         name: &StringKey, |         name: &StringKey, | ||||||
| @@ -100,8 +132,8 @@ impl MoveData { | |||||||
|         priority: i8, |         priority: i8, | ||||||
|         secondary_effect: Option<Box<dyn SecondaryEffect>>, |         secondary_effect: Option<Box<dyn SecondaryEffect>>, | ||||||
|         flags: HashSet<StringKey>, |         flags: HashSet<StringKey>, | ||||||
|     ) -> MoveData { |     ) -> Self { | ||||||
|         MoveData { |         Self { | ||||||
|             identifier: Default::default(), |             identifier: Default::default(), | ||||||
|             name: name.clone(), |             name: name.clone(), | ||||||
|             move_type, |             move_type, | ||||||
| @@ -115,58 +147,61 @@ impl MoveData { | |||||||
|             flags, |             flags, | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | impl MoveData for MoveDataImpl { | ||||||
|     /// The name of the move. |     /// The name of the move. | ||||||
|     pub fn name(&self) -> &StringKey { |     fn name(&self) -> &StringKey { | ||||||
|         &self.name |         &self.name | ||||||
|     } |     } | ||||||
|     /// The attacking type of the move. |     /// The attacking type of the move. | ||||||
|     pub fn move_type(&self) -> TypeIdentifier { |     fn move_type(&self) -> TypeIdentifier { | ||||||
|         self.move_type |         self.move_type | ||||||
|     } |     } | ||||||
|     /// The category of the move. |     /// The category of the move. | ||||||
|     pub fn category(&self) -> MoveCategory { |     fn category(&self) -> MoveCategory { | ||||||
|         self.category |         self.category | ||||||
|     } |     } | ||||||
|     /// The base power, not considering any modifiers, the move has. |     /// The base power, not considering any modifiers, the move has. | ||||||
|     pub fn base_power(&self) -> u8 { |     fn base_power(&self) -> u8 { | ||||||
|         self.base_power |         self.base_power | ||||||
|     } |     } | ||||||
|     /// The accuracy of the move in percentage. Should be 255 for moves that always hit. |     /// The accuracy of the move in percentage. Should be 255 for moves that always hit. | ||||||
|     pub fn accuracy(&self) -> u8 { |     fn accuracy(&self) -> u8 { | ||||||
|         self.accuracy |         self.accuracy | ||||||
|     } |     } | ||||||
|     /// The number of times the move can be used. This can be modified on actually learned moves using |     /// The number of times the move can be used. This can be modified on actually learned moves using | ||||||
|     /// PP-Ups |     /// PP-Ups | ||||||
|     pub fn base_usages(&self) -> u8 { |     fn base_usages(&self) -> u8 { | ||||||
|         self.base_usages |         self.base_usages | ||||||
|     } |     } | ||||||
|     /// How the move handles targets. |     /// How the move handles targets. | ||||||
|     pub fn target(&self) -> MoveTarget { |     fn target(&self) -> MoveTarget { | ||||||
|         self.target |         self.target | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /// The priority of the move. A higher priority means the move should go before other moves. |     /// The priority of the move. A higher priority means the move should go before other moves. | ||||||
|     pub fn priority(&self) -> i8 { |     fn priority(&self) -> i8 { | ||||||
|         self.priority |         self.priority | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /// The optional secondary effect the move has. |     /// The optional secondary effect the move has. | ||||||
|     pub fn secondary_effect(&self) -> &Option<Box<dyn SecondaryEffect>> { |     fn secondary_effect(&self) -> &Option<Box<dyn SecondaryEffect>> { | ||||||
|         &self.secondary_effect |         &self.secondary_effect | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /// Arbitrary flags that can be applied to the move. |     /// Arbitrary flags that can be applied to the move. | ||||||
|     pub fn has_flag(&self, key: &StringKey) -> bool { |     fn has_flag(&self, key: &StringKey) -> bool { | ||||||
|         self.flags.contains::<StringKey>(key) |         self.flags.contains::<StringKey>(key) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /// Arbitrary flags that can be applied to the move. |     /// Arbitrary flags that can be applied to the move. | ||||||
|     pub fn has_flag_by_hash(&self, key_hash: u32) -> bool { |     fn has_flag_by_hash(&self, key_hash: u32) -> bool { | ||||||
|         self.flags.contains::<u32>(&key_hash) |         self.flags.contains::<u32>(&key_hash) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| impl ValueIdentifiable for MoveData { | impl ValueIdentifiable for MoveDataImpl { | ||||||
|     fn value_identifier(&self) -> ValueIdentifier { |     fn value_identifier(&self) -> ValueIdentifier { | ||||||
|         self.identifier |         self.identifier | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -17,8 +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, MoveData, MoveLibrary, NatureImpl, NatureLibrary, |     ItemLibrary, LearnableMoves, LibrarySettings, LookupGrowthRate, MoveDataImpl, MoveLibrary, NatureImpl, | ||||||
|     SecondaryEffect, SecondaryEffectImpl, Species, StaticData, StaticStatisticSet, Statistic, TypeLibrary, |     NatureLibrary, SecondaryEffect, SecondaryEffectImpl, Species, StaticData, StaticStatisticSet, Statistic, | ||||||
|  |     TypeLibrary, | ||||||
| }; | }; | ||||||
| use pkmn_lib::StringKey; | use pkmn_lib::StringKey; | ||||||
|  |  | ||||||
| @@ -214,7 +215,7 @@ pub fn load_moves(path: &String, lib: &mut StaticData) { | |||||||
|  |  | ||||||
|         lib.moves_mut().add( |         lib.moves_mut().add( | ||||||
|             &move_name, |             &move_name, | ||||||
|             Arc::new(MoveData::new( |             Arc::new(MoveDataImpl::new( | ||||||
|                 &move_name.clone(), |                 &move_name.clone(), | ||||||
|                 move_type_id, |                 move_type_id, | ||||||
|                 move_category, |                 move_category, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user