sm64coopdx/data/dynos_mgr_col.cpp

67 lines
1.9 KiB
C++
Raw Normal View History

2022-04-08 17:18:06 +02:00
#include "dynos.cpp.h"
static Array<Pair<const char*, DataNode<Collision>*>>& DynosCollisions() {
static Array<Pair<const char*, DataNode<Collision>*>> sDynosCollisions;
return sDynosCollisions;
}
2022-04-08 17:18:06 +02:00
2022-04-16 22:05:10 +02:00
void DynOS_Col_Activate(const SysPath &aFilename, const char *aCollisionName) {
auto& _DynosCollisions = DynosCollisions();
2022-04-08 17:18:06 +02:00
// check for duplicates
for (s32 i = 0; i < _DynosCollisions.Count(); ++i) {
if (!strcmp(_DynosCollisions[i].first, aCollisionName)) {
2022-04-08 17:18:06 +02:00
return;
}
}
// Allocate name
u16 collisionLen = strlen(aCollisionName);
char* collisionName = (char*)calloc(1, sizeof(char) * (collisionLen + 1));
strcpy(collisionName, aCollisionName);
// Load
2022-04-16 22:05:10 +02:00
DataNode<Collision>* _Node = DynOS_Col_LoadFromBinary(aFilename, collisionName);
2022-04-08 17:18:06 +02:00
if (!_Node) {
free(collisionName);
return;
}
// Add to collisions
_DynosCollisions.Add({ collisionName, _Node });
2022-04-08 17:18:06 +02:00
}
Collision* DynOS_Col_Get(const char* collisionName) {
auto& _DynosCollisions = DynosCollisions();
2022-04-08 17:18:06 +02:00
// check levels
auto& levelsArray = DynOS_Lvl_GetArray();
for (auto& lvl : levelsArray) {
for (auto& col : lvl.second->mCollisions) {
if (col->mName == collisionName) {
return col->mData;
}
}
}
// check mod actor collisions
for (s32 i = 0; i < _DynosCollisions.Count(); ++i) {
if (!strcmp(_DynosCollisions[i].first, collisionName)) {
return _DynosCollisions[i].second->mData;
2022-04-08 17:18:06 +02:00
}
}
// check builtin collisions
return (Collision*)DynOS_Builtin_LvlCol_GetFromName(collisionName);
2022-04-08 17:18:06 +02:00
}
void DynOS_Col_ModShutdown() {
auto& _DynosCollisions = DynosCollisions();
while (_DynosCollisions.Count() > 0) {
auto& pair = _DynosCollisions[0];
free((void*)pair.first);
Delete(pair.second);
_DynosCollisions.Remove(0);
}
}