aboutsummaryrefslogtreecommitdiff
path: root/Src/pfc/grow_buf.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/pfc/grow_buf.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/pfc/grow_buf.cpp')
-rw-r--r--Src/pfc/grow_buf.cpp78
1 files changed, 78 insertions, 0 deletions
diff --git a/Src/pfc/grow_buf.cpp b/Src/pfc/grow_buf.cpp
new file mode 100644
index 00000000..627f70db
--- /dev/null
+++ b/Src/pfc/grow_buf.cpp
@@ -0,0 +1,78 @@
+#include "pfc.h"
+
+void grow_buf::makespace(int new_size)
+{
+ if (!ptr || !size)
+ {
+ size = 1;
+ while(size<new_size)
+ {
+ if (size == (1 << 31))
+ {
+ return;
+ }
+ size<<=1;
+ }
+ ptr = malloc(size);
+ }
+ else
+ {
+ if (size<new_size)
+ {
+ do
+ {
+ if (size == (1 << 31))
+ {
+ free(ptr);
+ ptr=0;
+ return;
+ }
+ size<<=1;
+ }
+ while (size<new_size);
+ ptr = realloc(ptr,size);
+ }
+ }
+}
+
+void * grow_buf::finish()
+{
+ void * rv=0;
+ if (ptr)
+ {
+ rv = realloc(ptr,used);
+ ptr = 0;
+ size = 0;
+ used = 0;
+ }
+ return rv;
+}
+
+void grow_buf::reset()
+{
+ if (ptr) {free(ptr);ptr=0;}
+ used=0;
+ size=0;
+}
+
+static void foo_memcpy(void * dst,const void * src,size_t bytes)
+{
+ if (src) memcpy(dst,src,bytes);
+ else memset(dst,0,bytes);
+}
+
+bool grow_buf::write(const void * data, size_t bytes)
+{
+ makespace(used+bytes);
+ if (!ptr)
+ return false;
+ foo_memcpy((char*)ptr+used,data,bytes);
+ used+=bytes;
+ return true;
+}
+
+void grow_buf::write_ptr(const void * data, int bytes,int offset)
+{
+ if (offset+bytes>used) {used = offset;write(data,bytes);}
+ else foo_memcpy((char*)ptr+offset,data,bytes);
+} \ No newline at end of file