Rename unique_identifier --> personality_value, minor fixes
continuous-integration/drone/push Build is passing
Details
continuous-integration/drone/push Build is passing
Details
This commit is contained in:
parent
bc9b3ed964
commit
f6df95a824
|
@ -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 {
|
||||
|
|
|
@ -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.
|
||||
|
|
|
@ -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.
|
||||
|
|
|
@ -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.
|
||||
|
|
|
@ -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(
|
||||
|
|
|
@ -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.
|
@ -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()));
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue