summaryrefslogtreecommitdiff
path: root/tools/shared.c
diff options
context:
space:
mode:
authorlordjaxom <lordjaxom>2005-02-10 22:24:26 +0000
committerlordjaxom <lordjaxom>2005-02-10 22:24:26 +0000
commitab8f0c75f39b57cd1e28545259fb08bb7b4925b3 (patch)
tree7b640887ef77c02bc09ffa0156684d76afa2492a /tools/shared.c
parentc1cb77c3f8c7c0b3469e1d110f4e9a96bac16178 (diff)
downloadvdr-plugin-streamdev-ab8f0c75f39b57cd1e28545259fb08bb7b4925b3.tar.gz
vdr-plugin-streamdev-ab8f0c75f39b57cd1e28545259fb08bb7b4925b3.tar.bz2
- implemented audio track selection for http
Diffstat (limited to 'tools/shared.c')
-rw-r--r--tools/shared.c90
1 files changed, 0 insertions, 90 deletions
diff --git a/tools/shared.c b/tools/shared.c
deleted file mode 100644
index ef20969..0000000
--- a/tools/shared.c
+++ /dev/null
@@ -1,90 +0,0 @@
-#include "tools/shared.h"
-
-#include <errno.h>
-#include <stddef.h>
-#include <string.h>
-
-cSharedData *cSharedData::Construct (size_t Length) {
- size_t reallength = sizeof(cSharedData) + Length;
- cSharedData *ret = (cSharedData*)new char[reallength];
-
- ret->m_Length = Length;
- ret->m_NumRefs = 0;
- return ret;
-}
-
-cTBShared::cTBShared(void) {
- m_Buffer = NULL;
-}
-
-cTBShared::cTBShared (const cTBShared &src) {
- m_Buffer = src.m_Buffer;
- if (m_Buffer)
- ++*m_Buffer;
-}
-
-cTBShared::~cTBShared () {
- if (m_Buffer)
- Release();
-}
-
-void cTBShared::Clear () {
- if (m_Buffer)
- Release();
- m_Buffer = 0;
-}
-
-void cTBShared::Set (const cTBShared &src) {
- if (m_Buffer)
- Release();
-
- m_Buffer = src.m_Buffer;
- if (m_Buffer)
- ++*m_Buffer;
-}
-
-void cTBShared::Release () {
- CHECK_PTR(m_Buffer);
-
- if (--*m_Buffer == 0)
- delete[] (char*)m_Buffer;
-
- m_Buffer = 0;
-}
-
-void cTBShared::Release(uint newsize) {
- CHECK_PTR(m_Buffer);
-
- Allocate(newsize, true);
-}
-
-void cTBShared::Exclusive () {
- CHECK_PTR(m_Buffer);
-
- if (m_Buffer->Refs() == 1)
- return;
-
- cSharedData *copy = cSharedData::Construct(m_Buffer->Size());
- memcpy(*copy, *m_Buffer, m_Buffer->Size());
-
- Release();
-
- m_Buffer = copy;
- ++*m_Buffer;
-}
-
-void cTBShared::Allocate (size_t len, bool keep /* = false */) {
- if (m_Buffer && (m_Buffer->Refs() == 1) && (m_Buffer->Size() == len))
- return;
-
- cSharedData *newBuffer = cSharedData::Construct(len);
- if (m_Buffer) {
- if (keep)
- memcpy(*newBuffer, *m_Buffer, len < m_Buffer->Size() ? len : m_Buffer->Size());
-
- Release();
- }
- m_Buffer = newBuffer;
- ++*m_Buffer;
-}
-