isle/LEGO1/mxstreamer.cpp
2023-09-19 15:17:54 -07:00

109 lines
2.0 KiB
C++

#include "mxstreamer.h"
#include "legoomni.h"
DECOMP_SIZE_ASSERT(MxStreamer, 0x2c);
// OFFSET: LEGO1 0x100b8f00
MxStreamer::MxStreamer()
{
NotificationManager()->Register(this);
}
// OFFSET: LEGO1 0x100b9190
MxResult MxStreamer::Init()
{
undefined *b = new undefined[m_subclass1.GetSize() * 0x5800];
m_subclass1.SetBuffer(b);
if (b) {
b = new undefined[m_subclass2.GetSize() * 0x800];
m_subclass2.SetBuffer(b);
if (b) {
return SUCCESS;
}
}
return FAILURE;
}
// OFFSET: LEGO1 0x100b91d0
MxStreamer::~MxStreamer()
{
while (!m_openStreams.empty()) {
MxStreamController *c = m_openStreams.front();
m_openStreams.pop_front();
delete c;
}
NotificationManager()->Unregister(this);
}
// OFFSET: LEGO1 0x100b92c0
MxStreamController *MxStreamer::Open(const char *name, MxU16 p_lookupType)
{
// TODO
MxStreamController *c = GetOpenStream(name);
return NULL;
}
// OFFSET: LEGO1 0x100b9570
MxLong MxStreamer::Close(const char *p)
{
MxDSAction ds;
ds.SetUnknown24(-2);
for (list<MxStreamController *>::iterator it = m_openStreams.begin(); it != m_openStreams.end(); it++) {
MxStreamController *c = *it;
if (!p || !strcmp(p, c->atom.GetInternal())) {
m_openStreams.erase(it);
if (c->IsStillInUse()) {
// TODO: Send notification to `c`
} else {
delete c;
}
return SUCCESS;
}
}
return FAILURE;
}
// OFFSET: LEGO1 0x100b9870
MxStreamController *MxStreamer::GetOpenStream(const char *p_name)
{
for (list<MxStreamController *>::iterator it = m_openStreams.begin(); it != m_openStreams.end(); it++) {
if (p_name) {
if (!strcmp(((*it)->atom.GetInternal()), p_name)) {
return *it;
}
}
}
return NULL;
}
// OFFSET: LEGO1 0x100b9b60
MxLong MxStreamer::Notify(MxParam &p)
{
// TODO
return 0;
}
// No offset, function is always inlined
MxStreamerSubClass1::MxStreamerSubClass1(undefined4 size)
{
m_buffer = NULL;
m_size = size;
undefined4 *ptr = &m_unk08;
for (int i = 0; i >= 0; i--) {
ptr[i] = 0;
}
}