summaryrefslogtreecommitdiff
path: root/arm7/lib/src/SND_work.c
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2021-08-31 08:54:33 -0400
committerPikalaxALT <pikalaxalt@gmail.com>2021-08-31 08:54:33 -0400
commitba5f5449a4fb7c36a20ebccb0aa560d88d6a49c0 (patch)
tree63e5cab56041641b85b231f09296d1cecf9e0a1c /arm7/lib/src/SND_work.c
parentcc891865fa1eb5a823f6a3eeb1746f05addb0d90 (diff)
parent1499e9f8be9458bbf94cbc4dc6d1034f53606cd0 (diff)
Merge branch 'pikalax_work' of github.com:PikalaxALT/pokediamond into pikalax_work
Diffstat (limited to 'arm7/lib/src/SND_work.c')
-rw-r--r--arm7/lib/src/SND_work.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/arm7/lib/src/SND_work.c b/arm7/lib/src/SND_work.c
new file mode 100644
index 00000000..2256ee3f
--- /dev/null
+++ b/arm7/lib/src/SND_work.c
@@ -0,0 +1,41 @@
+#include "SND_work.h"
+
+#include "SND_capture.h"
+#include "SND_channel.h"
+#include "SND_exChannel.h"
+
+struct SNDWork SNDi_Work;
+struct SNDSharedWork *SNDi_SharedWork;
+
+void SND_SetPlayerLocalVariable(int player, int var, s16 value)
+{
+ SNDi_SharedWork->players[player].localVars[var] = value;
+}
+
+void SND_SetPlayerGlobalVariable(int var, s16 value)
+{
+ SNDi_SharedWork->globalVars[var] = value;
+}
+
+void SND_UpdateSharedWork(void)
+{
+ u16 channelActiveMask = 0;
+ u16 channelCaptureMask = 0;
+
+ if (SNDi_SharedWork == NULL)
+ return;
+
+ for (s32 i = 0; i < SND_CHANNEL_COUNT; i++)
+ {
+ if (SND_IsChannelActive(i))
+ channelActiveMask |= 1 << i;
+ }
+
+ if (SND_IsCaptureActive(0))
+ channelCaptureMask |= 0x1;
+ if (SND_IsCaptureActive(1))
+ channelCaptureMask |= 0x2;
+
+ SNDi_SharedWork->channelStatus = channelActiveMask;
+ SNDi_SharedWork->captureStatus = channelCaptureMask;
+}