mirror of
https://github.com/hedge-dev/UnleashedRecomp
synced 2026-06-08 20:30:02 -04:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 3bd5aa94b4 |
@@ -0,0 +1,48 @@
|
|||||||
|
---
|
||||||
|
name: Bug Report
|
||||||
|
about: Report a bug in Unleashed Recompiled
|
||||||
|
type: Bug
|
||||||
|
---
|
||||||
|
|
||||||
|
### Validation
|
||||||
|
- [ ] I have checked the [Issues](https://github.com/hedge-dev/UnleashedRecomp/issues) page to see if my problem has already been reported
|
||||||
|
- [ ] I have confirmed that this bug does not occur in the original game running on original Xbox 360 hardware
|
||||||
|
|
||||||
|
#### If you have DLC installed, please specify which ones you have.
|
||||||
|
- [ ] Apotos & Shamar Adventure Pack
|
||||||
|
- [ ] Chun-nan Adventure Pack
|
||||||
|
- [ ] Empire City & Adabat Adventure Pack
|
||||||
|
- [ ] Holoska Adventure Pack
|
||||||
|
- [ ] Mazuri Adventure Pack
|
||||||
|
- [ ] Spagonia Adventure Pack
|
||||||
|
|
||||||
|
#### If you have mods enabled, please specify which ones you have.
|
||||||
|
Provide a list of your enabled mods in Hedge Mod Manager here. You will not receive support for issues *caused* by mods.
|
||||||
|
|
||||||
|
#### If you have codes enabled, please specify which ones you have.
|
||||||
|
Provide a list of your enabled codes in Hedge Mod Manager here.
|
||||||
|
|
||||||
|
### Describe the Bug
|
||||||
|
A clear and concise description of what the bug is.
|
||||||
|
|
||||||
|
### Steps to Reproduce
|
||||||
|
Steps to reproduce the bug:
|
||||||
|
1. Go to '...'
|
||||||
|
2. etc.
|
||||||
|
|
||||||
|
### Expected Behavior
|
||||||
|
A clear and concise description of what you expected to happen.
|
||||||
|
|
||||||
|
### Footage
|
||||||
|
Attach a screenshot or video of the bug. If possible, please also provide footage of the expected behaviour on original Xbox 360 hardware.
|
||||||
|
|
||||||
|
### Specifications
|
||||||
|
Fill out the following details:
|
||||||
|
- CPU: (e.g. Intel Core [...], AMD Ryzen [...], etc.)
|
||||||
|
- GPU: (e.g. NVIDIA GeForce [...], Radeon HD [...], Intel HD [...], etc.)
|
||||||
|
- GPU Driver: (e.g NVIDIA driver 545.XX, AMD driver 24.X.X, etc.)
|
||||||
|
- OS: (e.g. Windows 10, Windows 11, Linux distro)
|
||||||
|
- Version: (e.g. 1.0.0)
|
||||||
|
|
||||||
|
### Additional Context
|
||||||
|
Provide any other context about the problem here.
|
||||||
@@ -1,95 +0,0 @@
|
|||||||
name: Bug Report
|
|
||||||
description: Report a bug, crash, or other type of error in Unleashed Recompiled
|
|
||||||
type: Bug
|
|
||||||
body:
|
|
||||||
- id: validation
|
|
||||||
type: checkboxes
|
|
||||||
attributes:
|
|
||||||
label: Validation
|
|
||||||
options:
|
|
||||||
- label: I have checked the [Issues](https://github.com/hedge-dev/UnleashedRecomp/issues) page to see if my problem has already been reported
|
|
||||||
required: true
|
|
||||||
- label: I have confirmed that this bug does not occur in the original game running on original Xbox 360 hardware
|
|
||||||
required: false
|
|
||||||
- id: dlc-installed
|
|
||||||
type: checkboxes
|
|
||||||
attributes:
|
|
||||||
label: If you have DLC installed, please specify which ones you have.
|
|
||||||
options:
|
|
||||||
- label: Apotos & Shamar Adventure Pack
|
|
||||||
required: false
|
|
||||||
- label: Chun-nan Adventure Pack
|
|
||||||
required: false
|
|
||||||
- label: Empire City & Adabat Adventure Pack
|
|
||||||
required: false
|
|
||||||
- label: Holoska Adventure Pack
|
|
||||||
required: false
|
|
||||||
- label: Mazuri Adventure Pack
|
|
||||||
required: false
|
|
||||||
- label: Spagonia Adventure Pack
|
|
||||||
required: false
|
|
||||||
- id: mods-used
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: false
|
|
||||||
attributes:
|
|
||||||
label: If you have mods enabled, please specify which ones you have.
|
|
||||||
description: Provide a list of your enabled mods in Hedge Mod Manager here. You will not receive support for issues *caused* by mods.
|
|
||||||
- id: codes-used
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: false
|
|
||||||
attributes:
|
|
||||||
label: If you have codes enabled, please specify which ones you have.
|
|
||||||
description: Provide a list of your enabled codes in Hedge Mod Manager here.
|
|
||||||
- id: describe-bug
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
attributes:
|
|
||||||
label: Describe the Bug
|
|
||||||
description: A clear and concise description of what the bug is.
|
|
||||||
- id: repro-steps
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
attributes:
|
|
||||||
label: Steps to Reproduce
|
|
||||||
description: Step-by-step instructions on how to reproduce the bug.
|
|
||||||
placeholder: |
|
|
||||||
1. Go to '...'
|
|
||||||
2. etc.
|
|
||||||
- id: expected-behavior
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
attributes:
|
|
||||||
label: Expected Behavior
|
|
||||||
description: A clear and concise description of what you expected to happen.
|
|
||||||
- id: footage
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
attributes:
|
|
||||||
label: Footage
|
|
||||||
description: Attach a screenshot or video of the bug. If possible, please also provide footage of the expected behaviour on original Xbox 360 hardware.
|
|
||||||
- id: system-specifications
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
attributes:
|
|
||||||
label: System Specifications
|
|
||||||
description: Fill out the following details.
|
|
||||||
placeholder: |
|
|
||||||
- CPU: (e.g. Intel Core [...], AMD Ryzen [...], etc.)
|
|
||||||
- GPU: (e.g. NVIDIA GeForce [...], Radeon HD [...], Intel HD [...], etc.)
|
|
||||||
- GPU Driver: (e.g NVIDIA driver 545.XX, AMD driver 24.X.X, etc.)
|
|
||||||
- OS: (e.g. Windows 10, Windows 11, Linux distro)
|
|
||||||
- Version: (e.g. 1.0.0)
|
|
||||||
- id: additional-context
|
|
||||||
type: textarea
|
|
||||||
validations:
|
|
||||||
required: false
|
|
||||||
attributes:
|
|
||||||
label: Additional Context
|
|
||||||
description: Provide any other context about the problem here.
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
blank_issues_enabled: true
|
|
||||||
@@ -145,11 +145,13 @@ jobs:
|
|||||||
Move-Item -Path ".\out\build\${{ env.CMAKE_PRESET }}\UnleashedRecomp\dxil.dll" -Destination ".\release\dxil.dll"
|
Move-Item -Path ".\out\build\${{ env.CMAKE_PRESET }}\UnleashedRecomp\dxil.dll" -Destination ".\release\dxil.dll"
|
||||||
Move-Item -Path ".\out\build\${{ env.CMAKE_PRESET }}\UnleashedRecomp\UnleashedRecomp.exe" -Destination ".\release\UnleashedRecomp.exe"
|
Move-Item -Path ".\out\build\${{ env.CMAKE_PRESET }}\UnleashedRecomp\UnleashedRecomp.exe" -Destination ".\release\UnleashedRecomp.exe"
|
||||||
|
|
||||||
|
Compress-Archive -Path .\release\* -DestinationPath .\UnleashedRecomp-Windows.zip
|
||||||
|
|
||||||
- name: Upload Artifact
|
- name: Upload Artifact
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: UnleashedRecomp-Windows-${{ env.CMAKE_PRESET }}
|
name: UnleashedRecomp-Windows-${{ env.CMAKE_PRESET }}
|
||||||
path: .\release
|
path: .\UnleashedRecomp-Windows.zip
|
||||||
|
|
||||||
- name: Upload PDB
|
- name: Upload PDB
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
|
|||||||
@@ -278,16 +278,9 @@ Simply booting at least once in Desktop Mode will enable the Deck to use the fil
|
|||||||
|
|
||||||
## FAQ
|
## FAQ
|
||||||
|
|
||||||
### Do you have a website or Discord server?
|
### Do you have a Discord server?
|
||||||
|
|
||||||
Unleashed Recompiled does not have an official website, nor is it affiliated with any Discord servers.
|
Unleashed Recompiled is not associated with any Discord servers. Use the [Issues](https://github.com/hedge-dev/UnleashedRecomp/issues) page if you need support.
|
||||||
|
|
||||||
**Please link here when directing anyone to the project.**
|
|
||||||
|
|
||||||
> [!CAUTION]
|
|
||||||
> Do not download builds of Unleashed Recompiled from anywhere but our [Releases](https://github.com/hedge-dev/UnleashedRecomp/releases/latest) page.
|
|
||||||
>
|
|
||||||
> **We will never distribute builds on other websites, via Discord servers or via third-party update tools.**
|
|
||||||
|
|
||||||
### Why does the installer say my files are invalid?
|
### Why does the installer say my files are invalid?
|
||||||
|
|
||||||
|
|||||||
@@ -293,7 +293,7 @@ if (WIN32)
|
|||||||
add_executable(UnleashedRecomp ${UNLEASHED_RECOMP_CXX_SOURCES} "${CMAKE_BINARY_DIR}/res.rc")
|
add_executable(UnleashedRecomp ${UNLEASHED_RECOMP_CXX_SOURCES} "${CMAKE_BINARY_DIR}/res.rc")
|
||||||
|
|
||||||
# Hide console for release configurations.
|
# Hide console for release configurations.
|
||||||
if (${CMAKE_BUILD_TYPE} MATCHES "Release")
|
if (${CMAKE_BUILD_TYPE} MATCHES "Release" OR ${CMAKE_BUILD_TYPE} MATCHES "RelWithDebInfo")
|
||||||
target_link_options(UnleashedRecomp PRIVATE "/SUBSYSTEM:WINDOWS" "/ENTRY:mainCRTStartup")
|
target_link_options(UnleashedRecomp PRIVATE "/SUBSYSTEM:WINDOWS" "/ENTRY:mainCRTStartup")
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
@@ -352,7 +352,7 @@ if (WIN32)
|
|||||||
Synchronization
|
Synchronization
|
||||||
winmm
|
winmm
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
target_link_libraries(UnleashedRecomp PRIVATE
|
target_link_libraries(UnleashedRecomp PRIVATE
|
||||||
fmt::fmt
|
fmt::fmt
|
||||||
|
|||||||
@@ -8,7 +8,6 @@ public:
|
|||||||
static inline bool s_isInit;
|
static inline bool s_isInit;
|
||||||
static inline bool s_isMissingDLC;
|
static inline bool s_isMissingDLC;
|
||||||
static inline bool s_isLoading;
|
static inline bool s_isLoading;
|
||||||
static inline bool s_isSaving;
|
|
||||||
static inline bool s_isWerehog;
|
static inline bool s_isWerehog;
|
||||||
static inline bool s_isSaveDataCorrupt;
|
static inline bool s_isSaveDataCorrupt;
|
||||||
|
|
||||||
|
|||||||
@@ -38,11 +38,6 @@ static void CreateAudioDevice()
|
|||||||
|
|
||||||
void XAudioInitializeSystem()
|
void XAudioInitializeSystem()
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
|
||||||
// Force wasapi on Windows.
|
|
||||||
SDL_setenv("SDL_AUDIODRIVER", "wasapi", true);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
SDL_SetHint(SDL_HINT_AUDIO_CATEGORY, "playback");
|
SDL_SetHint(SDL_HINT_AUDIO_CATEGORY, "playback");
|
||||||
SDL_SetHint(SDL_HINT_AUDIO_DEVICE_APP_NAME, "Unleashed Recompiled");
|
SDL_SetHint(SDL_HINT_AUDIO_DEVICE_APP_NAME, "Unleashed Recompiled");
|
||||||
|
|
||||||
|
|||||||
@@ -692,17 +692,6 @@ std::unordered_map<std::string_view, std::unordered_map<ELanguage, std::string>>
|
|||||||
{ ELanguage::Italian, "Impossibile creare un backend D3D12 (Windows) o Vulkan.\n\nAssicurati che:\n\n- Il tuo sistema soddisfi i requisiti minimi.\n- I driver della scheda grafica siano aggiornati.\n- Il tuo sistema operativo sia aggiornato." }
|
{ ELanguage::Italian, "Impossibile creare un backend D3D12 (Windows) o Vulkan.\n\nAssicurati che:\n\n- Il tuo sistema soddisfi i requisiti minimi.\n- I driver della scheda grafica siano aggiornati.\n- Il tuo sistema operativo sia aggiornato." }
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"System_Win32_MissingDLLs",
|
|
||||||
{
|
|
||||||
{ ELanguage::English, "The module \"%s\" could not be found.\n\nPlease make sure that:\n\n- You extracted this copy of Unleashed Recompiled fully and not just the *.exe file.\n- You are not running Unleashed Recompiled from a *.zip file." },
|
|
||||||
{ ELanguage::Japanese, "モジュール\"%s\"が見つかりませんでした\n\n次の点を確認してください:\n\n※Unleashed Recompiledの*.exeファイルだけを抽出していなく、 コピーを完全に抽出してること\n※Unleashed Recompiledを*.zipファイルから実行していないこと" },
|
|
||||||
{ ELanguage::German, "Das Modul \"%s\" konnte nicht gefunden werden.\n\nBitte stelle sicher, dass:\n\n- Diese Kopie von Unleashed Recompiled vollständig entpackt wurde und nicht nur die *.exe-Datei.\n- Unleashed Recompiled nicht direkt aus einer *.zip-Datei ausgeführt wird." },
|
|
||||||
{ ELanguage::French, "Le module \"%s\" n'a pas pu être trouvé.\n\nVeuillez vous assurer que :\n\n- Vous avez extrait Unleashed Recompiled dans son entièreté et pas seulement le fichier *.exe.\n- Vous n'exécutez pas Unleashed Recompiled à partir d'un fichier *.zip." },
|
|
||||||
{ ELanguage::Spanish, "No se pudo encontrar el módulo \"%s\".\n\nAsegúrese de que:\n\n- Ha extraido esta copia de Unleashed Recompiled por completo y no solo el archivo *.exe.\n- No está ejecutando Unleashed Recompiled desde un archivo *.zip." },
|
|
||||||
{ ELanguage::Italian, "Impossibile trovare il modulo \"%s\".\n\nAssicurati che:\n\n- Hai estratto questa copia di Unleashed Recompiled correttamente e non solo il file *.exe.\n- Non stai eseguendo Unleashed Recompiled da un file *.zip." }
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"Common_On",
|
"Common_On",
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
#include <stdafx.h>
|
#include <stdafx.h>
|
||||||
#include <cpuid.h>
|
|
||||||
#include <cpu/guest_thread.h>
|
#include <cpu/guest_thread.h>
|
||||||
#include <gpu/video.h>
|
#include <gpu/video.h>
|
||||||
#include <kernel/function.h>
|
#include <kernel/function.h>
|
||||||
@@ -28,15 +27,6 @@
|
|||||||
#include <timeapi.h>
|
#include <timeapi.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(_WIN32) && defined(UNLEASHED_RECOMP_D3D12)
|
|
||||||
static std::array<std::string_view, 3> g_D3D12RequiredModules =
|
|
||||||
{
|
|
||||||
"D3D12/D3D12Core.dll",
|
|
||||||
"dxcompiler.dll",
|
|
||||||
"dxil.dll"
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
const size_t XMAIOBegin = 0x7FEA0000;
|
const size_t XMAIOBegin = 0x7FEA0000;
|
||||||
const size_t XMAIOEnd = XMAIOBegin + 0x0000FFFF;
|
const size_t XMAIOEnd = XMAIOBegin + 0x0000FFFF;
|
||||||
|
|
||||||
@@ -157,29 +147,6 @@ uint32_t LdrLoadModule(const std::filesystem::path &path)
|
|||||||
return entry;
|
return entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
__attribute__((constructor(101), target("no-avx,no-avx2"), noinline))
|
|
||||||
void init()
|
|
||||||
{
|
|
||||||
#ifdef __x86_64__
|
|
||||||
uint32_t eax, ebx, ecx, edx;
|
|
||||||
|
|
||||||
// Execute CPUID for processor info and feature bits.
|
|
||||||
__get_cpuid(1, &eax, &ebx, &ecx, &edx);
|
|
||||||
|
|
||||||
// Check for AVX support.
|
|
||||||
if ((ecx & (1 << 28)) == 0)
|
|
||||||
{
|
|
||||||
printf("[*] CPU does not support the AVX instruction set.\n");
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
MessageBoxA(nullptr, "Your CPU does not meet the minimum system requirements.", "Unleashed Recompiled", MB_ICONERROR);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
std::_Exit(1);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
@@ -189,7 +156,7 @@ int main(int argc, char *argv[])
|
|||||||
os::process::CheckConsole();
|
os::process::CheckConsole();
|
||||||
|
|
||||||
if (!os::registry::Init())
|
if (!os::registry::Init())
|
||||||
LOGN_WARNING("OS does not support registry.");
|
LOGN_WARNING("OS doesn't support registry");
|
||||||
|
|
||||||
os::logger::Init();
|
os::logger::Init();
|
||||||
|
|
||||||
@@ -213,19 +180,6 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
Config::Load();
|
Config::Load();
|
||||||
|
|
||||||
#if defined(_WIN32) && defined(UNLEASHED_RECOMP_D3D12)
|
|
||||||
for (auto& dll : g_D3D12RequiredModules)
|
|
||||||
{
|
|
||||||
if (!std::filesystem::exists(g_executableRoot / dll))
|
|
||||||
{
|
|
||||||
char text[512];
|
|
||||||
snprintf(text, sizeof(text), Localise("System_Win32_MissingDLLs").c_str(), dll.data());
|
|
||||||
SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_ERROR, GameWindow::GetTitle(), text, GameWindow::s_pWindow);
|
|
||||||
std::_Exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Check the time since the last time an update was checked. Store the new time if the difference is more than six hours.
|
// Check the time since the last time an update was checked. Store the new time if the difference is more than six hours.
|
||||||
constexpr double TimeBetweenUpdateChecksInSeconds = 6 * 60 * 60;
|
constexpr double TimeBetweenUpdateChecksInSeconds = 6 * 60 * 60;
|
||||||
time_t timeNow = std::time(nullptr);
|
time_t timeNow = std::time(nullptr);
|
||||||
|
|||||||
@@ -212,7 +212,7 @@ g_sdlEventListenerForInputPatches;
|
|||||||
|
|
||||||
static bool IsDPadThreshold(const SWA::SPadState* pPadState)
|
static bool IsDPadThreshold(const SWA::SPadState* pPadState)
|
||||||
{
|
{
|
||||||
if (Config::DisableDPadMovement)
|
if (Config::DisableDPadAsAnalogInput)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return pPadState->IsDown(SWA::eKeyState_DpadUp) ||
|
return pPadState->IsDown(SWA::eKeyState_DpadUp) ||
|
||||||
@@ -240,7 +240,7 @@ static bool IsCursorThreshold(double deadzone = 0, bool isBelowThreshold = false
|
|||||||
|
|
||||||
static void SetDPadAnalogDirectionX(PPCRegister& pPadState, PPCRegister& x, bool invert, float max = 1.0f)
|
static void SetDPadAnalogDirectionX(PPCRegister& pPadState, PPCRegister& x, bool invert, float max = 1.0f)
|
||||||
{
|
{
|
||||||
if (Config::DisableDPadMovement)
|
if (Config::DisableDPadAsAnalogInput)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
||||||
@@ -254,7 +254,7 @@ static void SetDPadAnalogDirectionX(PPCRegister& pPadState, PPCRegister& x, bool
|
|||||||
|
|
||||||
static void SetDPadAnalogDirectionY(PPCRegister& pPadState, PPCRegister& y, bool invert, float max = 1.0f)
|
static void SetDPadAnalogDirectionY(PPCRegister& pPadState, PPCRegister& y, bool invert, float max = 1.0f)
|
||||||
{
|
{
|
||||||
if (Config::DisableDPadMovement)
|
if (Config::DisableDPadAsAnalogInput)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
||||||
@@ -292,7 +292,7 @@ void PostureDPadSupportYMidAsmHook(PPCRegister& pPadState, PPCRegister& y)
|
|||||||
|
|
||||||
void PostureSpaceHurrierDPadSupportXMidAsmHook(PPCRegister& pPadState, PPCVRegister& vector)
|
void PostureSpaceHurrierDPadSupportXMidAsmHook(PPCRegister& pPadState, PPCVRegister& vector)
|
||||||
{
|
{
|
||||||
if (Config::DisableDPadMovement)
|
if (Config::DisableDPadAsAnalogInput)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
||||||
@@ -306,7 +306,7 @@ void PostureSpaceHurrierDPadSupportXMidAsmHook(PPCRegister& pPadState, PPCVRegis
|
|||||||
|
|
||||||
void PostureSpaceHurrierDPadSupportYMidAsmHook(PPCRegister& pPadState, PPCVRegister& vector)
|
void PostureSpaceHurrierDPadSupportYMidAsmHook(PPCRegister& pPadState, PPCVRegister& vector)
|
||||||
{
|
{
|
||||||
if (Config::DisableDPadMovement)
|
if (Config::DisableDPadAsAnalogInput)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
auto pGuestPadState = (SWA::SPadState*)g_memory.Translate(pPadState.u32);
|
||||||
@@ -318,18 +318,6 @@ void PostureSpaceHurrierDPadSupportYMidAsmHook(PPCRegister& pPadState, PPCVRegis
|
|||||||
vector.f32[3] = -1.0f;
|
vector.f32[3] = -1.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetXButtonHomingMidAsmHook(PPCRegister& r1)
|
|
||||||
{
|
|
||||||
auto pXButtonHoming = (bool*)(g_memory.base + r1.u32 + 0x63);
|
|
||||||
|
|
||||||
*pXButtonHoming = !Config::HomingAttackOnJump;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool IsHomingAttackOnJump()
|
|
||||||
{
|
|
||||||
return Config::HomingAttackOnJump;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ------------- WORLD MAP ------------- //
|
// ------------- WORLD MAP ------------- //
|
||||||
|
|
||||||
bool WorldMapDeadzoneMidAsmHook(PPCRegister& pPadState)
|
bool WorldMapDeadzoneMidAsmHook(PPCRegister& pPadState)
|
||||||
@@ -430,7 +418,7 @@ PPC_FUNC(sub_8256C938)
|
|||||||
pWorldMapCursor->m_LeftStickVertical = rPadState.LeftStickVertical;
|
pWorldMapCursor->m_LeftStickVertical = rPadState.LeftStickVertical;
|
||||||
pWorldMapCursor->m_LeftStickHorizontal = rPadState.LeftStickHorizontal;
|
pWorldMapCursor->m_LeftStickHorizontal = rPadState.LeftStickHorizontal;
|
||||||
|
|
||||||
if (!Config::DisableDPadMovement)
|
if (!Config::DisableDPadAsAnalogInput)
|
||||||
{
|
{
|
||||||
if (rPadState.IsDown(SWA::eKeyState_DpadUp))
|
if (rPadState.IsDown(SWA::eKeyState_DpadUp))
|
||||||
pWorldMapCursor->m_LeftStickVertical = 1.0f;
|
pWorldMapCursor->m_LeftStickVertical = 1.0f;
|
||||||
|
|||||||
@@ -95,6 +95,13 @@ void PostUnleashMidAsmHook(PPCRegister& r30)
|
|||||||
g_isUnleashCancelled = false;
|
g_isUnleashCancelled = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SetXButtonHomingMidAsmHook(PPCRegister& r1)
|
||||||
|
{
|
||||||
|
auto pXButtonHoming = (bool*)(g_memory.base + r1.u32 + 0x63);
|
||||||
|
|
||||||
|
*pXButtonHoming = !Config::HomingAttackOnJump;
|
||||||
|
}
|
||||||
|
|
||||||
// SWA::Player::CEvilSonicContext
|
// SWA::Player::CEvilSonicContext
|
||||||
PPC_FUNC_IMPL(__imp__sub_823B49D8);
|
PPC_FUNC_IMPL(__imp__sub_823B49D8);
|
||||||
PPC_FUNC(sub_823B49D8)
|
PPC_FUNC(sub_823B49D8)
|
||||||
@@ -116,42 +123,3 @@ PPC_FUNC(sub_823B4590)
|
|||||||
|
|
||||||
SDL_User_EvilSonic(false);
|
SDL_User_EvilSonic(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Change state to squat kick.
|
|
||||||
PPC_FUNC_IMPL(__imp__sub_8236FE88);
|
|
||||||
PPC_FUNC(sub_8236FE88)
|
|
||||||
{
|
|
||||||
if (Config::DisableSquatKick)
|
|
||||||
{
|
|
||||||
ctx.r3.u32 = 0;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
__imp__sub_8236FE88(ctx, base);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Change state to drift.
|
|
||||||
PPC_FUNC_IMPL(__imp__sub_82370A50);
|
|
||||||
PPC_FUNC(sub_82370A50)
|
|
||||||
{
|
|
||||||
if (ctx.r4.u32)
|
|
||||||
{
|
|
||||||
if (Config::DisableDriftOnSlide)
|
|
||||||
{
|
|
||||||
if (auto pInputState = SWA::CInputState::GetInstance())
|
|
||||||
{
|
|
||||||
auto& rPadState = pInputState->GetPadState();
|
|
||||||
|
|
||||||
if (!rPadState.IsDown(SWA::eKeyState_LeftTrigger) && !rPadState.IsDown(SWA::eKeyState_RightTrigger))
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (Config::DisableDriftOnBrake)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
__imp__sub_82370A50(ctx, base);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -97,8 +97,6 @@ PPC_FUNC(sub_824E5170)
|
|||||||
|
|
||||||
__imp__sub_824E5170(ctx, base);
|
__imp__sub_824E5170(ctx, base);
|
||||||
|
|
||||||
App::s_isSaving = pSaveIcon->m_IsVisible;
|
|
||||||
|
|
||||||
if (pSaveIcon->m_IsVisible)
|
if (pSaveIcon->m_IsVisible)
|
||||||
{
|
{
|
||||||
App::s_isSaveDataCorrupt = false;
|
App::s_isSaveDataCorrupt = false;
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
VERSION_MILESTONE=""
|
VERSION_MILESTONE=""
|
||||||
VERSION_MAJOR=1
|
VERSION_MAJOR=1
|
||||||
VERSION_MINOR=0
|
VERSION_MINOR=0
|
||||||
VERSION_REVISION=2
|
VERSION_REVISION=1
|
||||||
|
|||||||
@@ -34,14 +34,8 @@ int Window_OnSDLEvent(void*, SDL_Event* event)
|
|||||||
switch (event->type)
|
switch (event->type)
|
||||||
{
|
{
|
||||||
case SDL_QUIT:
|
case SDL_QUIT:
|
||||||
{
|
|
||||||
if (App::s_isSaving)
|
|
||||||
break;
|
|
||||||
|
|
||||||
App::Exit();
|
App::Exit();
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
case SDL_KEYDOWN:
|
case SDL_KEYDOWN:
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -79,12 +79,7 @@ CONFIG_DEFINE_HIDDEN("Codes", bool, AllowCancellingUnleash, false);
|
|||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableAutoSaveWarning, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableAutoSaveWarning, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableBoostFilter, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableBoostFilter, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDLCIcon, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDLCIcon, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDPadMovement, false);
|
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDriftOnBrake, false);
|
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDriftOnSlide, false);
|
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDWMRoundedCorners, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDWMRoundedCorners, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableLowResolutionFontOnCustomUI, false);
|
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableSquatKick, false);
|
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, EnableEventCollisionDebugView, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, EnableEventCollisionDebugView, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, EnableGIMipLevelDebugView, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, EnableGIMipLevelDebugView, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, EnableObjectCollisionDebugView, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, EnableObjectCollisionDebugView, false);
|
||||||
@@ -97,5 +92,7 @@ CONFIG_DEFINE_HIDDEN("Codes", bool, SaveScoreAtCheckpoints, false);
|
|||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, SkipIntroLogos, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, SkipIntroLogos, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, UseArrowsForTimeOfDayTransition, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, UseArrowsForTimeOfDayTransition, false);
|
||||||
CONFIG_DEFINE_HIDDEN("Codes", bool, UseOfficialTitleOnTitleBar, false);
|
CONFIG_DEFINE_HIDDEN("Codes", bool, UseOfficialTitleOnTitleBar, false);
|
||||||
|
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableLowResolutionFontOnCustomUI, false);
|
||||||
|
CONFIG_DEFINE_HIDDEN("Codes", bool, DisableDPadAsAnalogInput, false);
|
||||||
|
|
||||||
CONFIG_DEFINE("Update", time_t, LastChecked, 0);
|
CONFIG_DEFINE("Update", time_t, LastChecked, 0);
|
||||||
|
|||||||
@@ -8,8 +8,6 @@
|
|||||||
#define GAME_INSTALL_DIRECTORY "."
|
#define GAME_INSTALL_DIRECTORY "."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern std::filesystem::path g_executableRoot;
|
|
||||||
|
|
||||||
inline std::filesystem::path GetGamePath()
|
inline std::filesystem::path GetGamePath()
|
||||||
{
|
{
|
||||||
return GAME_INSTALL_DIRECTORY;
|
return GAME_INSTALL_DIRECTORY;
|
||||||
|
|||||||
@@ -181,8 +181,8 @@ jump_address_on_true = 0x829E40A0
|
|||||||
# Disable Chip hints for shoe upgrades
|
# Disable Chip hints for shoe upgrades
|
||||||
[[midasm_hook]]
|
[[midasm_hook]]
|
||||||
name = "DisableHintsMidAsmHook"
|
name = "DisableHintsMidAsmHook"
|
||||||
address = 0x82691DD0
|
address = 0x82691CB0
|
||||||
jump_address_on_true = 0x82691DD4
|
jump_address_on_true = 0x82691E24
|
||||||
|
|
||||||
# Disable navigation volumes
|
# Disable navigation volumes
|
||||||
[[midasm_hook]]
|
[[midasm_hook]]
|
||||||
@@ -197,18 +197,11 @@ address = 0x823A4FF0
|
|||||||
registers = ["r4", "r5"]
|
registers = ["r4", "r5"]
|
||||||
return_on_false = true
|
return_on_false = true
|
||||||
|
|
||||||
# Set default value for XButtonHoming.
|
|
||||||
[[midasm_hook]]
|
[[midasm_hook]]
|
||||||
name = "SetXButtonHomingMidAsmHook"
|
name = "SetXButtonHomingMidAsmHook"
|
||||||
address = 0x8237AC90
|
address = 0x8237AC90
|
||||||
registers = ["r1"]
|
registers = ["r1"]
|
||||||
|
|
||||||
# Disable XML reading for XButtonHoming.
|
|
||||||
[[midasm_hook]]
|
|
||||||
name = "IsHomingAttackOnJump"
|
|
||||||
address = 0x8237ACE4
|
|
||||||
jump_address_on_true = 0x8237ACE8
|
|
||||||
|
|
||||||
# Down force HFR fix
|
# Down force HFR fix
|
||||||
[[midasm_hook]]
|
[[midasm_hook]]
|
||||||
name = "DownForceDeltaTimeFixMidAsmHook"
|
name = "DownForceDeltaTimeFixMidAsmHook"
|
||||||
|
|||||||
+1
-1
Submodule tools/XenonRecomp updated: 7b8e37aa37...cd6fcb33bd
Reference in New Issue
Block a user