summaryrefslogtreecommitdiffstats
path: root/src/include/fileringbuffer.h
blob: 2978becbb7f72cd3cc4cafa2f2f84c97b8e2afd9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/***************************************************************************
                          ringbuffer.h  -  description
                             -------------------
    begin                : Sun March 21 2004
    copyright            : (C) 2004 by Martin Witte
    email                : [email protected]
 ***************************************************************************/

/***************************************************************************
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License as published by  *
 *   the Free Software Foundation; either version 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 ***************************************************************************/

#ifndef _KRADIO_FILE_RING_BUFFER_H
#define _KRADIO_FILE_RING_BUFFER_H

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <tqstring.h>
#include <stdio.h>

class FileRingBuffer
{
public:
    FileRingBuffer(const TQString &filename, TQ_UINT64 max_size);
    ~FileRingBuffer();

    bool       resize(const TQString &filename, TQ_UINT64 new_max_size);

    size_t     addData (const char *src, size_t size);
    size_t     takeData(char *dst, size_t size);
    TQ_UINT64   removeData(TQ_UINT64 size);

    const TQString &getFileName () const { return m_FileName; }
    TQ_UINT64       getMaxSize()   const { return m_MaxSize;  }
    TQ_UINT64       getRealSize()  const { return m_RealSize; }
    TQ_UINT64       getFillSize()  const { return m_FillSize; }
    TQ_UINT64       getFreeSize()  const { return (m_Start + m_FillSize > m_RealSize) ? m_RealSize - m_FillSize : m_MaxSize - m_FillSize; }

    void       clear();

    bool           error()       const { return m_error; }
    const TQString &errorString() const { return m_errorString; }

protected:
    TQ_UINT64    getFreeSpace(TQ_UINT64 &size);  // returns position in file + size
    TQ_UINT64    removeFreeSpace(TQ_UINT64 size);

    TQ_UINT64    getData(TQ_UINT64 &size);  // returns position in file + size


    int        m_FileIdx;
    TQString    m_BaseFileName;
    TQString    m_FileName;
    FILE      *m_File;
    TQ_UINT64   m_Start;
    TQ_UINT64   m_MaxSize;
    TQ_UINT64   m_RealSize;
    TQ_UINT64   m_FillSize;

    TQString   m_errorString;
    bool      m_error;
};

#endif