3D Audio GSoC:
[blender.git] / intern / audaspace / intern / AUD_ConverterReader.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_ConverterReader.cpp
28  *  \ingroup audaspaceintern
29  */
30
31
32 #include "AUD_ConverterReader.h"
33
34 AUD_ConverterReader::AUD_ConverterReader(AUD_Reference<AUD_IReader> reader,
35                                                                                  AUD_DeviceSpecs specs) :
36                 AUD_EffectReader(reader)
37 {
38         m_specs.specs = reader->getSpecs();
39
40         int bigendian = 1;
41         bigendian = (((char*)&bigendian)[0]) ? 0: 1; // 1 if Big Endian
42
43         switch(specs.format)
44         {
45         case AUD_FORMAT_U8:
46                 m_convert = AUD_convert_float_u8;
47                 break;
48         case AUD_FORMAT_S16:
49                 m_convert = AUD_convert_float_s16;
50                 break;
51         case AUD_FORMAT_S24:
52                 if(bigendian)
53                         m_convert = AUD_convert_float_s24_be;
54                 else
55                         m_convert = AUD_convert_float_s24_le;
56                 break;
57         case AUD_FORMAT_S32:
58                 m_convert = AUD_convert_float_s32;
59                 break;
60         case AUD_FORMAT_FLOAT32:
61                 m_convert = AUD_convert_copy<float>;
62                 break;
63         case AUD_FORMAT_FLOAT64:
64                 m_convert = AUD_convert_float_double;
65                 break;
66         default:
67                 break;
68         }
69
70         m_specs.format = specs.format;
71 }
72
73 AUD_Specs AUD_ConverterReader::getSpecs() const
74 {
75         return m_specs.specs;
76 }
77
78 void AUD_ConverterReader::read(int & length, sample_t* buffer)
79 {
80         int samplesize = AUD_SAMPLE_SIZE(m_reader->getSpecs());
81
82         if(m_buffer.getSize() < length * samplesize)
83                 m_buffer.resize(length * samplesize);
84
85         m_reader->read(length, m_buffer.getBuffer());
86
87         m_convert((data_t*)buffer, (data_t*)m_buffer.getBuffer(),
88                           length * m_specs.channels);
89 }