mirror of
https://github.com/hedge-dev/UnleashedRecomp
synced 2026-06-10 04:54:37 -04:00
Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 3f9f83941d | |||
| 5e8695a157 |
@@ -351,6 +351,8 @@ if (UNLEASHED_RECOMP_FLATPAK)
|
||||
"GAME_INSTALL_DIRECTORY=\"/var/data\""
|
||||
)
|
||||
endif()
|
||||
|
||||
target_compile_definitions(UnleashedRecomp PRIVATE $<$<CONFIG:Debug>:UNLEASHED_RECOMP_DEBUG=1>)
|
||||
|
||||
find_package(CURL REQUIRED)
|
||||
|
||||
|
||||
@@ -3145,7 +3145,7 @@ static GuestTexture* CreateTexture(uint32_t width, uint32_t height, uint32_t dep
|
||||
|
||||
g_textureDescriptorSet->setTexture(texture->descriptorIndex, texture->texture, RenderTextureLayout::SHADER_READ, texture->textureView.get());
|
||||
|
||||
#ifdef _DEBUG
|
||||
#ifdef UNLEASHED_RECOMP_DEBUG
|
||||
texture->texture->setName(fmt::format("Texture {:X}", g_memory.MapVirtual(texture)));
|
||||
#endif
|
||||
|
||||
@@ -3162,7 +3162,7 @@ static GuestBuffer* CreateVertexBuffer(uint32_t length)
|
||||
auto buffer = g_userHeap.AllocPhysical<GuestBuffer>(ResourceType::VertexBuffer);
|
||||
buffer->buffer = g_device->createBuffer(RenderBufferDesc::VertexBuffer(length, GetBufferHeapType(), RenderBufferFlag::INDEX));
|
||||
buffer->dataSize = length;
|
||||
#ifdef _DEBUG
|
||||
#ifdef UNLEASHED_RECOMP_DEBUG
|
||||
buffer->buffer->setName(fmt::format("Vertex Buffer {:X}", g_memory.MapVirtual(buffer)));
|
||||
#endif
|
||||
return buffer;
|
||||
@@ -3175,7 +3175,7 @@ static GuestBuffer* CreateIndexBuffer(uint32_t length, uint32_t, uint32_t format
|
||||
buffer->dataSize = length;
|
||||
buffer->format = ConvertFormat(format);
|
||||
buffer->guestFormat = format;
|
||||
#ifdef _DEBUG
|
||||
#ifdef UNLEASHED_RECOMP_DEBUG
|
||||
buffer->buffer->setName(fmt::format("Index Buffer {:X}", g_memory.MapVirtual(buffer)));
|
||||
#endif
|
||||
return buffer;
|
||||
@@ -3213,7 +3213,7 @@ static GuestSurface* CreateSurface(uint32_t width, uint32_t height, uint32_t for
|
||||
surface->descriptorIndex = g_textureDescriptorAllocator.allocate();
|
||||
g_textureDescriptorSet->setTexture(surface->descriptorIndex, surface->textureHolder.get(), RenderTextureLayout::SHADER_READ, surface->textureView.get());
|
||||
|
||||
#ifdef _DEBUG
|
||||
#ifdef UNLEASHED_RECOMP_DEBUG
|
||||
surface->texture->setName(fmt::format("{} {:X}", desc.flags & RenderTextureFlag::RENDER_TARGET ? "Render Target" : "Depth Stencil", g_memory.MapVirtual(surface)));
|
||||
#endif
|
||||
|
||||
@@ -5857,7 +5857,7 @@ static void MakePictureData(GuestPictureData* pictureData, uint8_t* data, uint32
|
||||
|
||||
if (LoadTexture(texture, data, dataSize, {}))
|
||||
{
|
||||
#ifdef _DEBUG
|
||||
#ifdef UNLEASHED_RECOMP_DEBUG
|
||||
texture.texture->setName(reinterpret_cast<char*>(g_memory.Translate(pictureData->name + 2)));
|
||||
#endif
|
||||
XXH64_hash_t hash = XXH3_64bits(data, dataSize);
|
||||
|
||||
@@ -203,7 +203,7 @@ uint32_t XamShowMessageBoxUI(uint32_t dwUserIndex, be<uint16_t>* wszTitle, be<ui
|
||||
{
|
||||
*pResult = cButtons ? cButtons - 1 : 0;
|
||||
|
||||
#if _DEBUG
|
||||
#if UNLEASHED_RECOMP_DEBUG
|
||||
assert("XamShowMessageBoxUI encountered!" && false);
|
||||
#elif _WIN32
|
||||
// This code is Win32-only as it'll most likely crash, misbehave or
|
||||
|
||||
@@ -11,7 +11,7 @@
|
||||
#define LOG_WARNING(str) LOG_IMPL(Warning, __func__, str)
|
||||
#define LOG_ERROR(str) LOG_IMPL(Error, __func__, str)
|
||||
|
||||
#if _DEBUG
|
||||
#if UNLEASHED_RECOMP_DEBUG
|
||||
#define LOG_UTILITY(str) LOG_IMPL(Utility, __func__, str)
|
||||
#else
|
||||
#define LOG_UTILITY(str)
|
||||
@@ -21,7 +21,7 @@
|
||||
#define LOGF_WARNING(str, ...) LOGF_IMPL(Warning, __func__, str, __VA_ARGS__)
|
||||
#define LOGF_ERROR(str, ...) LOGF_IMPL(Error, __func__, str, __VA_ARGS__)
|
||||
|
||||
#if _DEBUG
|
||||
#if UNLEASHED_RECOMP_DEBUG
|
||||
#define LOGF_UTILITY(str, ...) LOGF_IMPL(Utility, __func__, str, __VA_ARGS__)
|
||||
#else
|
||||
#define LOGF_UTILITY(str, ...)
|
||||
@@ -33,7 +33,7 @@
|
||||
#define LOGN_WARNING(str) LOG_IMPL(Warning, "*", str)
|
||||
#define LOGN_ERROR(str) LOG_IMPL(Error, "*", str)
|
||||
|
||||
#if _DEBUG
|
||||
#if UNLEASHED_RECOMP_DEBUG
|
||||
#define LOGN_UTILITY(str) LOG_IMPL(Utility, "*", str)
|
||||
#else
|
||||
#define LOGN_UTILITY(str)
|
||||
@@ -43,7 +43,7 @@
|
||||
#define LOGFN_WARNING(str, ...) LOGF_IMPL(Warning, "*", str, __VA_ARGS__)
|
||||
#define LOGFN_ERROR(str, ...) LOGF_IMPL(Error, "*", str, __VA_ARGS__)
|
||||
|
||||
#if _DEBUG
|
||||
#if UNLEASHED_RECOMP_DEBUG
|
||||
#define LOGFN_UTILITY(str, ...) LOGF_IMPL(Utility, "*", str, __VA_ARGS__)
|
||||
#else
|
||||
#define LOGFN_UTILITY(str, ...)
|
||||
|
||||
@@ -195,3 +195,11 @@ bool SparkleLocusMidAsmHook()
|
||||
// This has the side effect of the locus particle eventually snapping to the rest position during pause, but it's better than vertices exploding.
|
||||
return App::s_deltaTime < (1.0 / 60.0);
|
||||
}
|
||||
|
||||
void CEvilSonicContext_CStateWall_LeaveRotationMidAsmHook(PPCRegister& f1)
|
||||
{
|
||||
// The code in the Werehog's "wall" state for leaving walls adds a constant
|
||||
// value of 0.05 to his transform every frame. This makes the value respect
|
||||
// delta time whilst maintaining the original behaviour at 30 FPS.
|
||||
f1.f64 = f1.f64 * (std::min(App::s_deltaTime, 1.0 / 15.0) / (1.0 / 30.0));
|
||||
}
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
#define UNLEASHED_RECOMP_VERSION_BIN @WIN32_VERSION_BINARY@
|
||||
#define UNLEASHED_RECOMP_VERSION_STR "@WIN32_VERSION_STRING@"
|
||||
|
||||
#ifdef _DEBUG
|
||||
#ifdef UNLEASHED_RECOMP_DEBUG
|
||||
#define UNLEASHED_RECOMP_FILE_FLAGS VS_FF_DEBUG
|
||||
#else
|
||||
#define UNLEASHED_RECOMP_FILE_FLAGS 0
|
||||
|
||||
@@ -817,7 +817,7 @@ void Config::Load()
|
||||
{
|
||||
def->ReadValue(toml);
|
||||
|
||||
#if _DEBUG
|
||||
#if UNLEASHED_RECOMP_DEBUG
|
||||
LOGFN_UTILITY("{} (0x{:X})", def->GetDefinition().c_str(), (intptr_t)def->GetValue());
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -1141,3 +1141,15 @@ registers = ["r3"]
|
||||
name = "EndingTextPositionMidAsmHook"
|
||||
address = 0x82580168
|
||||
registers = ["r31", "f13"]
|
||||
|
||||
# Wall Leave - Left
|
||||
[[midasm_hook]]
|
||||
name = "CEvilSonicContext_CStateWall_LeaveRotationMidAsmHook"
|
||||
address = 0x824067BC
|
||||
registers = ["f1"]
|
||||
|
||||
# Wall Leave - Right
|
||||
[[midasm_hook]]
|
||||
name = "CEvilSonicContext_CStateWall_LeaveRotationMidAsmHook"
|
||||
address = 0x82406774
|
||||
registers = ["f1"]
|
||||
|
||||
Reference in New Issue
Block a user