rna polygon access to loop vertex indicies.
[blender-staging.git] / intern / audaspace / FX / AUD_BaseIIRFilterReader.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/FX/AUD_BaseIIRFilterReader.cpp
28  *  \ingroup audfx
29  */
30
31
32 #include "AUD_BaseIIRFilterReader.h"
33
34 #include <cstring>
35
36 #define CC m_channels + m_channel
37
38 AUD_BaseIIRFilterReader::AUD_BaseIIRFilterReader(AUD_IReader* reader, int in,
39                                                                                                  int out) :
40                 AUD_EffectReader(reader),
41                 m_channels(reader->getSpecs().channels),
42                 m_xlen(in), m_ylen(out),
43                 m_xpos(0), m_ypos(0), m_channel(0)
44 {
45         m_x = new sample_t[in * m_channels];
46         m_y = new sample_t[out * m_channels];
47
48         memset(m_x, 0, sizeof(sample_t) * in * m_channels);
49         memset(m_y, 0, sizeof(sample_t) * out * m_channels);
50 }
51
52 AUD_BaseIIRFilterReader::~AUD_BaseIIRFilterReader()
53 {
54         delete[] m_x;
55         delete[] m_y;
56 }
57
58 void AUD_BaseIIRFilterReader::read(int & length, sample_t* & buffer)
59 {
60         sample_t* buf;
61
62         int samplesize = AUD_SAMPLE_SIZE(m_reader->getSpecs());
63
64         m_reader->read(length, buf);
65
66         if(m_buffer.getSize() < length * samplesize)
67                 m_buffer.resize(length * samplesize);
68
69         buffer = m_buffer.getBuffer();
70
71         for(m_channel = 0; m_channel < m_channels; m_channel++)
72         {
73                 for(int i = 0; i < length; i++)
74                 {
75                         m_x[m_xpos * CC] = buf[i * CC];
76                         m_y[m_ypos * CC] = buffer[i * CC] = filter();
77
78                         m_xpos = (m_xpos + 1) % m_xlen;
79                         m_ypos = (m_ypos + 1) % m_ylen;
80                 }
81         }
82 }