mirror of
https://github.com/jugeeya/UltimateTrainingModpack.git
synced 2025-01-20 01:10:13 +00:00
Mash Fixes (#140)
* Fix Shield Toggle Fixed air dodging when shield is buffered * Update Mash Reset Fixed followups not being cleared on reset (training mode/ save state/ tech) Fixed resetting when landing after a mash toggle * Version + * Use Existing Constant * Adjust Versioning
This commit is contained in:
parent
1835be9cfb
commit
53c361686f
3 changed files with 19 additions and 16 deletions
|
@ -38,7 +38,7 @@ include $(DEVKITPRO)/libnx/switch_rules
|
|||
# NACP building is skipped as well.
|
||||
#---------------------------------------------------------------------------------
|
||||
APP_TITLE := Training Modpack
|
||||
APP_VERSION := 2.6beta
|
||||
APP_VERSION := 2.4.1beta
|
||||
|
||||
TARGET := ovlTrainingModpack
|
||||
BUILD := build
|
||||
|
|
|
@ -3,8 +3,8 @@ use crate::common::*;
|
|||
use crate::training::character_specific;
|
||||
use crate::training::fast_fall;
|
||||
use crate::training::full_hop;
|
||||
use crate::training::shield;
|
||||
use crate::training::sdi;
|
||||
use crate::training::shield;
|
||||
use smash::app::{self, lua_bind::*};
|
||||
use smash::lib::lua_const::*;
|
||||
|
||||
|
@ -52,7 +52,7 @@ pub fn get_current_buffer() -> Action {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn reset() {
|
||||
fn reset() {
|
||||
unsafe {
|
||||
QUEUE.pop();
|
||||
}
|
||||
|
@ -60,6 +60,14 @@ pub fn reset() {
|
|||
shield::suspend_shield(get_current_buffer());
|
||||
}
|
||||
|
||||
pub fn full_reset(){
|
||||
unsafe{
|
||||
while QUEUE.len() > 0 {
|
||||
reset();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn set_aerial(attack: Action) {
|
||||
if !shield::is_aerial(attack) {
|
||||
return;
|
||||
|
@ -113,7 +121,7 @@ unsafe fn check_buffer(module_accessor: &mut app::BattleObjectModuleAccessor) {
|
|||
and to reset when using the training mode reset
|
||||
*/
|
||||
if should_reset(module_accessor) {
|
||||
reset();
|
||||
full_reset();
|
||||
}
|
||||
|
||||
return;
|
||||
|
@ -137,16 +145,8 @@ fn should_reset(module_accessor: &mut app::BattleObjectModuleAccessor) -> bool {
|
|||
prev_status = StatusModule::prev_status_kind(module_accessor, 0);
|
||||
}
|
||||
|
||||
// Don't reset after teching
|
||||
if prev_status == *FIGHTER_STATUS_KIND_DOWN {
|
||||
return false;
|
||||
}
|
||||
|
||||
if prev_status == *FIGHTER_STATUS_KIND_PASSIVE {
|
||||
return false;
|
||||
}
|
||||
|
||||
if prev_status == *FIGHTER_STATUS_KIND_PASSIVE_FB {
|
||||
// Only reset on training mode reset
|
||||
if prev_status != *FIGHTER_STATUS_KIND_NONE {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -233,6 +233,9 @@ unsafe fn perform_action(module_accessor: &mut app::BattleObjectModuleAccessor)
|
|||
);
|
||||
}
|
||||
Action::SHIELD => {
|
||||
if !is_grounded(module_accessor) {
|
||||
return 0;
|
||||
}
|
||||
/*
|
||||
Doesn't actually cause the shield, but will clear the buffer once shield is possible.
|
||||
Shield hold is performed through shield::should_hold_shield and request_shield
|
||||
|
@ -454,7 +457,7 @@ fn try_change_status(
|
|||
}
|
||||
|
||||
pub unsafe fn perform_defensive_option() {
|
||||
reset();
|
||||
full_reset();
|
||||
|
||||
let action = match MENU.defensive_state.get_random() {
|
||||
Defensive::ROLL_F => Action::ROLL_F,
|
||||
|
|
|
@ -95,7 +95,7 @@ pub unsafe fn save_states(module_accessor: &mut app::BattleObjectModuleAccessor,
|
|||
SAVE_STATE_PLAYER.state = KillPlayer;
|
||||
SAVE_STATE_CPU.state = KillPlayer;
|
||||
}
|
||||
mash::reset();
|
||||
mash::full_reset();
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue