3D Audio GSoC:
[blender.git] / intern / audaspace / intern / AUD_StreamBufferFactory.cpp
1 /*
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * Copyright 2009-2011 Jörg Hermann Müller
7  *
8  * This file is part of AudaSpace.
9  *
10  * Audaspace is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * AudaSpace is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with Audaspace; if not, write to the Free Software Foundation,
22  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 /** \file audaspace/intern/AUD_StreamBufferFactory.cpp
28  *  \ingroup audaspaceintern
29  */
30
31
32 #include "AUD_StreamBufferFactory.h"
33 #include "AUD_BufferReader.h"
34 #include "AUD_Buffer.h"
35
36 #include <cstring>
37
38 AUD_StreamBufferFactory::AUD_StreamBufferFactory(AUD_Reference<AUD_IFactory> factory) :
39         m_buffer(new AUD_Buffer())
40 {
41         AUD_Reference<AUD_IReader> reader = factory->createReader();
42
43         m_specs = reader->getSpecs();
44
45         int sample_size = AUD_SAMPLE_SIZE(m_specs);
46         int length;
47         int index = 0;
48
49         // get an approximated size if possible
50         int size = reader->getLength();
51
52         if(size <= 0)
53                 size = AUD_BUFFER_RESIZE_BYTES / sample_size;
54         else
55                 size += m_specs.rate;
56
57         // as long as we fill our buffer to the end
58         while(index == m_buffer->getSize() / sample_size)
59         {
60                 // increase
61                 m_buffer->resize(size*sample_size, true);
62
63                 // read more
64                 length = size-index;
65                 reader->read(length, m_buffer->getBuffer() + index * m_specs.channels);
66                 size += AUD_BUFFER_RESIZE_BYTES / sample_size;
67                 index += length;
68         }
69
70         m_buffer->resize(index * sample_size, true);
71 }
72
73 AUD_Reference<AUD_IReader> AUD_StreamBufferFactory::createReader() const
74 {
75         return new AUD_BufferReader(m_buffer, m_specs);
76 }