Rename unique_identifier --> personality_value, minor fixes

This commit is contained in:
Deukhoofd 2023-07-09 11:17:43 +02:00
parent bc9b3ed964
commit f6df95a824
Signed by: Deukhoofd
GPG Key ID: F63E044490819F6F
8 changed files with 70 additions and 46 deletions
src
dynamic_data/models
ffi/dynamic_data/models
script_implementations/wasm/export_registry/dynamic_data
tests

View File

@ -50,8 +50,8 @@ struct PokemonData {
level: Atomic<LevelInt>,
/// The amount of experience of the Pokemon.
experience: AtomicU32,
/// A unique random number for this Pokemon.
unique_identifier: u32,
/// The personality value of the Pokemon.
personality_value: u32,
/// The gender of the Pokemon.
gender: RwLock<Gender>,
@ -171,7 +171,7 @@ impl Pokemon {
display_form: None,
level: Atomic::new(level),
experience: AtomicU32::new(experience),
unique_identifier,
personality_value: unique_identifier,
gender: RwLock::new(gender),
coloring,
held_item: RwLock::new(None),
@ -239,16 +239,19 @@ impl Pokemon {
}
}
/// The current level of the Pokemon.
/// [See also](https://bulbapedia.bulbagarden.net/wiki/Level)
pub fn level(&self) -> LevelInt {
self.data.level.load(Ordering::Relaxed)
}
/// The amount of experience of the Pokemon.
/// [See also](https://bulbapedia.bulbagarden.net/wiki/Experience)
pub fn experience(&self) -> u32 {
self.data.experience.load(Ordering::Relaxed)
}
/// A unique random number for this Pokemon.
pub fn unique_identifier(&self) -> u32 {
self.data.unique_identifier
/// The personality value of the Pokemon.
/// [See also](https://bulbapedia.bulbagarden.net/wiki/Personality_value)
pub fn personality_value(&self) -> u32 {
self.data.personality_value
}
/// The gender of the Pokemon.
pub fn gender(&self) -> Gender {

View File

@ -3,7 +3,7 @@ use parking_lot::lock_api::RwLockReadGuard;
use parking_lot::{RawRwLock, RwLock};
use crate::dynamic_data::models::pokemon::Pokemon;
use crate::VecExt;
use crate::{PkmnError, VecExt};
/// A list of Pokemon belonging to a trainer.
#[derive(Debug)]
@ -43,8 +43,18 @@ impl PokemonParty {
}
/// Swaps two Pokemon in the party around.
pub fn switch(&self, a: usize, b: usize) {
pub fn switch(&self, a: usize, b: usize) -> Result<()> {
let write_lock = self.pokemon.write();
if a >= write_lock.len() || b >= write_lock.len() {
return Err(PkmnError::IndexOutOfBounds {
index: if a >= write_lock.len() { a } else { b },
len: write_lock.len(),
}
.into());
}
self.pokemon.write().swap(a, b);
Ok(())
}
/// Sets the Pokemon at an index to a Pokemon, returning the old Pokemon.

View File

@ -76,21 +76,24 @@ extern "C" fn pokemon_display_form(handle: FFIHandle<Pokemon>) -> FFIHandle<Arc<
}
/// The level of the Pokemon.
/// [See also](https://bulbapedia.bulbagarden.net/wiki/Level)
#[no_mangle]
extern "C" fn pokemon_level(handle: FFIHandle<Pokemon>) -> LevelInt {
handle.from_ffi_handle().level()
}
/// The experience of the Pokemon.
/// [See also](https://bulbapedia.bulbagarden.net/wiki/Experience)
#[no_mangle]
extern "C" fn pokemon_experience(handle: FFIHandle<Pokemon>) -> u32 {
handle.from_ffi_handle().experience()
}
/// The unique identifier of the Pokemon.
/// The personality value of the Pokemon.
/// [See also](https://bulbapedia.bulbagarden.net/wiki/Personality_value)
#[no_mangle]
extern "C" fn pokemon_unique_identifier(handle: FFIHandle<Pokemon>) -> u32 {
handle.from_ffi_handle().unique_identifier()
extern "C" fn pokemon_personality_value(handle: FFIHandle<Pokemon>) -> u32 {
handle.from_ffi_handle().personality_value()
}
/// The gender of the Pokemon.

View File

@ -19,10 +19,10 @@ extern "C" fn pokemon_party_at(ptr: FFIHandle<Arc<PokemonParty>>, index: usize)
}
}
/// Gets a Pokemon at an index in the party.
/// Swaps two Pokemon in the party around.
#[no_mangle]
extern "C" fn pokemon_party_switch(ptr: FFIHandle<Arc<PokemonParty>>, a: usize, b: usize) {
ptr.from_ffi_handle().switch(a, b);
extern "C" fn pokemon_party_switch(ptr: FFIHandle<Arc<PokemonParty>>, a: usize, b: usize) -> FFIResult<()> {
ptr.from_ffi_handle().switch(a, b).into()
}
/// Sets the Pokemon at an index to a Pokemon, returning the old Pokemon.

View File

@ -448,11 +448,11 @@ register! {
wasm_ok(get_value_call_getter!(pokemon.experience(), env))
}
fn pokemon_get_unique_identifier(
fn pokemon_get_personality_value(
env: FunctionEnvMut<WebAssemblyEnv>,
pokemon: ExternRef<Pokemon>,
) -> WasmResult<u32> {
wasm_ok(get_value_call_getter!(pokemon.unique_identifier(), env))
wasm_ok(get_value_call_getter!(pokemon.personality_value(), env))
}
fn pokemon_get_coloring(

View File

@ -63,7 +63,7 @@
"mirror"
],
"effect": {
"name": "ChangeTargetSpDef",
"name": "change_target_special_defense",
"chance": 10,
"parameters": [
-1
@ -83,7 +83,7 @@
"snatch"
],
"effect": {
"name": "ChangeTargetDef",
"name": "change_target_defense",
"chance": -1,
"parameters": [
2
@ -127,7 +127,7 @@
"ballistics"
],
"effect": {
"name": "ChangeTargetSpDef",
"name": "change_target_special_defense",
"chance": -1,
"parameters": [
-2
@ -150,7 +150,7 @@
"distance"
],
"effect": {
"name": "Acrobatics",
"name": "acrobatics",
"chance": -1
}
},
@ -165,7 +165,7 @@
"category": "status",
"flags": [],
"effect": {
"name": "Acupressure",
"name": "acupressure",
"chance": -1
}
},
@ -200,7 +200,7 @@
"distance"
],
"effect": {
"name": "IncreasedCriticalStage"
"name": "increased_critical_stage"
}
},
{
@ -216,7 +216,7 @@
"ignore-substitute"
],
"effect": {
"name": "AfterYou"
"name": "after_you"
}
},
{
@ -232,7 +232,7 @@
"snatch"
],
"effect": {
"name": "ChangeTargetSpeed",
"name": "change_target_speed",
"parameters": [
2
]
@ -252,7 +252,7 @@
"mirror"
],
"effect": {
"name": "IncreasedCriticalStage"
"name": "increased_critical_stage"
}
},
{
@ -270,7 +270,7 @@
"distance"
],
"effect": {
"name": "Flinch",
"name": "flinch",
"chance": 30
}
},
@ -323,7 +323,7 @@
"snatch"
],
"effect": {
"name": "ChangeTargetSpDef",
"name": "change_target_special_defense",
"parameters": [
2
]
@ -344,7 +344,7 @@
"mirror"
],
"effect": {
"name": "PreventFoeRunning"
"name": "prevent_foes_exit"
}
},
{
@ -361,7 +361,7 @@
"mirror"
],
"effect": {
"name": "ChangeAllTargetStats",
"name": "change_all_target_stats",
"chance": 10,
"parameters": [
1
@ -396,7 +396,7 @@
"snatch"
],
"effect": {
"name": "HealEachEndOfTurn",
"name": "heal_each_end_of_turn",
"parameters": [
6.25
]
@ -432,7 +432,7 @@
"mirror"
],
"effect": {
"name": "2_5HitMove"
"name": "2_5_hit_move"
}
},
{
@ -449,7 +449,7 @@
"distance"
],
"effect": {
"name": "CurePartyStatus"
"name": "cure_party_status"
}
},
{
@ -465,7 +465,7 @@
"ignore-substitute"
],
"effect": {
"name": "ChangeTargetSpDef",
"name": "change_target_special_defense",
"parameters": [
1
]
@ -500,7 +500,7 @@
"mirror"
],
"effect": {
"name": "Assurance"
"name": "double_power_if_target_damaged_in_turn"
}
},
{
@ -536,7 +536,7 @@
"mirror"
],
"effect": {
"name": "IncreasedCriticalStage"
"name": "increased_critical_stage"
}
},
{
@ -556,7 +556,7 @@
"mental"
],
"effect": {
"name": "Attract"
"name": "attract"
}
},
{
@ -590,9 +590,11 @@
"mirror"
],
"effect": {
"name": "ChangeTargetAtt",
"name": "change_target_attack",
"chance": 10,
"parameters": [-1]
"parameters": [
-1
]
}
},
{
@ -621,7 +623,7 @@
"snatch"
],
"effect": {
"name": "Automize"
"name": "automize"
}
},
{
@ -639,7 +641,7 @@
"mirror"
],
"effect": {
"name": "ModifyDamageIfHitByTarget"
"name": "double_power_user_damaged_by_target_in_turn"
}
},
{
@ -657,8 +659,10 @@
"mirror"
],
"effect": {
"name": "ChangeTargetAtt",
"parameters": [-1]
"name": "change_target_attack",
"parameters": [
-1
]
}
},
{

Binary file not shown.

View File

@ -115,14 +115,18 @@ fn validate_assurance() {
battle.sides()[1].set_pokemon(0, Some(p2.clone())).unwrap();
let script = lib
.load_script(ScriptOwnerData::None, ScriptCategory::Move, &"assurance".into())
.load_script(
ScriptOwnerData::None,
ScriptCategory::Move,
&"double_power_if_target_damaged_in_turn".into(),
)
.unwrap()
.unwrap();
let mv = p1.learned_moves().read()[0].as_ref().unwrap().clone();
let choice = Arc::new(TurnChoice::Move(MoveChoice::new(p1.clone(), mv.clone(), 1, 0)));
script.on_before_turn(&choice).unwrap();
assert!(battle.sides()[1].has_volatile_script(&"assurance_data".into()));
assert!(battle.sides()[1].has_volatile_script(&"double_power_if_target_damaged_in_turn_data".into()));
let executing_move = Arc::new(ExecutingMove::new(
vec![],
@ -136,7 +140,7 @@ fn validate_assurance() {
script.change_base_power(&executing_move, &p2, 0, &mut v).unwrap();
assert_eq!(v, 20_u8);
let s = battle.sides()[1].get_volatile_script(&"assurance_data".into());
let s = battle.sides()[1].get_volatile_script(&"double_power_if_target_damaged_in_turn_data".into());
let binding = s.as_ref().unwrap().get().unwrap().read();
let data_script = binding.as_ref().unwrap();
@ -147,5 +151,5 @@ fn validate_assurance() {
assert_eq!(v, 40_u8);
data_script.on_end_turn().unwrap();
assert!(!battle.sides()[1].has_volatile_script(&"assurance_data".into()));
assert!(!battle.sides()[1].has_volatile_script(&"double_power_if_target_damaged_in_turn_data".into()));
}