aboutsummaryrefslogtreecommitdiff
path: root/Src/nu/bitbuffer.cpp
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/nu/bitbuffer.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/nu/bitbuffer.cpp')
-rw-r--r--Src/nu/bitbuffer.cpp71
1 files changed, 71 insertions, 0 deletions
diff --git a/Src/nu/bitbuffer.cpp b/Src/nu/bitbuffer.cpp
new file mode 100644
index 00000000..0e3d61db
--- /dev/null
+++ b/Src/nu/bitbuffer.cpp
@@ -0,0 +1,71 @@
+#include "bitbuffer.h"
+#include <memory.h>
+#include <stdlib.h>
+
+BitBuffer::BitBuffer()
+{
+ buffer=0;
+ length=0;
+ bits=0;
+}
+
+void BitBuffer::WriteBit(char bit)
+{
+ if (bits == 0)
+ Resize(length+1);
+
+ bit = !!bit;
+ unsigned char mask = 1 << (7-bits);
+ buffer[length-1] &= ~mask;
+ buffer[length-1] |= (bit << (7-bits));
+ bits=(bits+1)%8;
+}
+
+void BitBuffer::Resize(size_t newlen)
+{
+ if (newlen > length)
+ {
+ unsigned char *new_buffer = (unsigned char *)realloc(buffer, newlen);
+ if (new_buffer)
+ {
+ buffer = new_buffer;
+ memset(buffer+length, 0, newlen-length); // zero out new data
+ length=newlen;
+ }
+ else
+ {
+ new_buffer = (unsigned char *)malloc(newlen);
+ if (new_buffer)
+ {
+ memcpy(new_buffer, buffer, length);
+ free(buffer);
+ buffer = new_buffer;
+ memset(buffer+length, 0, newlen-length); // zero out new data
+ length=newlen;
+ }
+ }
+ }
+}
+
+void BitBuffer::WriteBits(uintptr_t num, size_t bitlen)
+{
+ for (size_t i=0;i!=bitlen;i++)
+ {
+ WriteBit((num >> (bitlen-i-1))&1);
+ }
+}
+
+void BitBuffer::WriteBytes(void *buffer, size_t bytes)
+{
+ unsigned char *b = (unsigned char *)buffer;
+ for (size_t i=0;i!=bytes;i++)
+ WriteBits(b[i], 8);
+}
+
+void BitBuffer::WriteByte(unsigned char byte)
+{
+ for (size_t i=0;i!=8;i++)
+ {
+ WriteBit((byte >> (7-i))&1);
+ }
+} \ No newline at end of file