mirror of
https://github.com/isledecomp/isle-portable.git
synced 2026-01-14 03:31:14 +00:00
* chore: update README.md * ✨ feat: got the audio working * 🔧 feat: add appxmanifest * 🩹 fix: remove opengl stuff * ⚗️ feat: add button support * ⚗️ chore: try to make less modification from upstream * 🩹 fix: doesnt compile * ✨ feat: forcibly draw cursor and map right joystick to cursor * 🩹 fix: remap joystick * 🎨 fix: formatting * 🎨 fix: cmakelists formatting * 🩹 fix: 3ds build * 👷 feat: add xbox one ci build * 💚 fix: github hates xbox series naming * 💚 fix: dont run cpack for xbox one, vs does that for you * 💚 fix: xbox one need to use vs as generator * 💚 fix: please * 💚 fix: it could be msix not bundle * 💚 fix: try recursive directory search when upload release * 🔨 feat: support cpack * 👷 feat: better packaging * 💚 fix: ignore if mv fails * 🔧 feat: add mouse sensitivity config * 🔥 chore: dont need you * ⚗️ chore: use d3d11 * ✨ feat: hardware acceleration!! * 🚸 chore: change default cd path so user can easily copy the assets to xbox * 🧑💻 chore: improve reusability * 🚨 fix: formatting error * 🚸 chore: draw cursor by default * 🎨 chore: cmakelists formatting * chore: match with upstream * chore: more matching with upstream * chore: don't need you * 🩹 fix: apply changes * 🔥 fix: we don't need controller map anymore * 🩹 fix: use isle style include guard * 🩹 fix: last newline fix * 👷 chore: use cpack * 💚 fix: try to fix ci * 💚 fix: i tried my best...
162 lines
3.9 KiB
C++
162 lines
3.9 KiB
C++
#include "mxramstreamprovider.h"
|
|
|
|
#include "decomp.h"
|
|
#include "mxdsbuffer.h"
|
|
#include "mxdsfile.h"
|
|
#include "mxomni.h"
|
|
#include "mxstreamcontroller.h"
|
|
#include "mxutilities.h"
|
|
|
|
DECOMP_SIZE_ASSERT(MxStreamProvider, 0x10)
|
|
DECOMP_SIZE_ASSERT(MxRAMStreamProvider, 0x24)
|
|
|
|
// FUNCTION: LEGO1 0x100d0730
|
|
MxRAMStreamProvider::MxRAMStreamProvider()
|
|
{
|
|
m_bufferSize = 0;
|
|
m_fileSize = 0;
|
|
m_pBufferOfFileSize = NULL;
|
|
m_lengthInDWords = 0;
|
|
m_bufferForDWords = NULL;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100d0930
|
|
MxU32 MxRAMStreamProvider::GetFileSize()
|
|
{
|
|
return m_fileSize;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100d0940
|
|
MxS32 MxRAMStreamProvider::GetStreamBuffersNum()
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100d0950
|
|
MxU32 MxRAMStreamProvider::GetLengthInDWords()
|
|
{
|
|
return m_lengthInDWords;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100d0960
|
|
MxU32* MxRAMStreamProvider::GetBufferForDWords()
|
|
{
|
|
return m_bufferForDWords;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100d0a50
|
|
MxRAMStreamProvider::~MxRAMStreamProvider()
|
|
{
|
|
m_bufferSize = 0;
|
|
m_fileSize = 0;
|
|
|
|
delete[] m_pBufferOfFileSize;
|
|
m_pBufferOfFileSize = NULL;
|
|
|
|
m_lengthInDWords = 0;
|
|
|
|
delete[] m_bufferForDWords;
|
|
m_bufferForDWords = NULL;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100d0ae0
|
|
MxResult MxRAMStreamProvider::SetResourceToGet(MxStreamController* p_resource)
|
|
{
|
|
MxResult result = FAILURE;
|
|
MxString path;
|
|
m_pLookup = p_resource;
|
|
|
|
path = (MxString(MxOmni::GetHD()) + p_resource->GetAtom().GetInternal() + ".si");
|
|
|
|
m_pFile = new MxDSFile(path.GetData(), 0);
|
|
if (m_pFile != NULL) {
|
|
if (m_pFile->Open(MxDSFile::e_openRead) != 0) {
|
|
path = MxString(MxOmni::GetCD()) + p_resource->GetAtom().GetInternal() + ".si";
|
|
m_pFile->SetFileName(path.GetData());
|
|
|
|
if (m_pFile->Open(MxDSFile::e_openRead) != 0) {
|
|
goto done;
|
|
}
|
|
}
|
|
|
|
m_fileSize = m_pFile->CalcFileSize();
|
|
if (m_fileSize != 0) {
|
|
m_bufferSize = m_pFile->GetBufferSize();
|
|
m_pBufferOfFileSize = new MxU8[m_fileSize];
|
|
if (m_pBufferOfFileSize != NULL &&
|
|
m_pFile->Read((unsigned char*) m_pBufferOfFileSize, m_fileSize) == SUCCESS) {
|
|
m_lengthInDWords = m_pFile->GetLengthInDWords();
|
|
m_bufferForDWords = new MxU32[m_lengthInDWords];
|
|
|
|
if (m_bufferForDWords != NULL) {
|
|
memcpy(m_bufferForDWords, m_pFile->GetBuffer(), m_lengthInDWords * sizeof(MxU32));
|
|
result = SUCCESS;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
done:
|
|
delete m_pFile;
|
|
m_pFile = NULL;
|
|
return result;
|
|
}
|
|
|
|
// FUNCTION: LEGO1 0x100d0d80
|
|
// FUNCTION: BETA10 0x1016492f
|
|
MxU32 ReadData(MxU8* p_buffer, MxU32 p_size)
|
|
{
|
|
MxU32 id;
|
|
MxU8* data = p_buffer;
|
|
MxU8* data2 = NULL;
|
|
|
|
while (data < p_buffer + p_size) {
|
|
if (data + sizeof(MxU32) <= p_buffer + p_size && UnalignedRead<MxU32>(data) == FOURCC('M', 'x', 'O', 'b')) {
|
|
data2 = data;
|
|
data = data2 + 8;
|
|
|
|
MxDSObject* obj = DeserializeDSObjectDispatch(data, -1);
|
|
id = obj->GetObjectId();
|
|
delete obj;
|
|
|
|
data = MxDSChunk::End(data2);
|
|
while (data + sizeof(MxU32) < p_buffer + p_size) {
|
|
if (UnalignedRead<MxU32>(data) == FOURCC('M', 'x', 'C', 'h')) {
|
|
MxU8* data3 = data;
|
|
data = MxDSChunk::End(data3);
|
|
|
|
if ((UnalignedRead<MxU32>(data2) == FOURCC('M', 'x', 'C', 'h')) &&
|
|
(*MxStreamChunk::IntoFlags(data2) & DS_CHUNK_SPLIT)) {
|
|
if (*MxStreamChunk::IntoObjectId(data2) == *MxStreamChunk::IntoObjectId(data3) &&
|
|
(*MxStreamChunk::IntoFlags(data3) & DS_CHUNK_SPLIT) &&
|
|
*MxStreamChunk::IntoTime(data2) == *MxStreamChunk::IntoTime(data3)) {
|
|
MxDSBuffer::Append(data2, data3);
|
|
continue;
|
|
}
|
|
else {
|
|
*MxStreamChunk::IntoFlags(data2) &= ~DS_CHUNK_SPLIT;
|
|
}
|
|
}
|
|
|
|
data2 = MxDSChunk::End(data2);
|
|
memmove(data2, data3, MxDSChunk::Size(data3));
|
|
|
|
if (UnalignedRead<MxU32>((MxU8*) MxStreamChunk::IntoObjectId(data2)) == id &&
|
|
(*MxStreamChunk::IntoFlags(data2) & DS_CHUNK_END_OF_STREAM)) {
|
|
break;
|
|
}
|
|
}
|
|
else {
|
|
data++;
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
data++;
|
|
}
|
|
}
|
|
|
|
*MxStreamChunk::IntoFlags(data2) &= ~DS_CHUNK_SPLIT;
|
|
return MxDSChunk::Size(data2) + (MxU32) (data2 - p_buffer);
|
|
}
|