Blender  V2.59
AUD_SilenceReader.cpp
Go to the documentation of this file.
00001 /*
00002  * $Id: AUD_SilenceReader.cpp 35141 2011-02-25 10:21:56Z jesterking $
00003  *
00004  * ***** BEGIN GPL LICENSE BLOCK *****
00005  *
00006  * Copyright 2009-2011 Jörg Hermann Müller
00007  *
00008  * This file is part of AudaSpace.
00009  *
00010  * Audaspace is free software; you can redistribute it and/or modify
00011  * it under the terms of the GNU General Public License as published by
00012  * the Free Software Foundation; either version 2 of the License, or
00013  * (at your option) any later version.
00014  *
00015  * AudaSpace is distributed in the hope that it will be useful,
00016  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00017  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00018  * GNU General Public License for more details.
00019  *
00020  * You should have received a copy of the GNU General Public License
00021  * along with Audaspace; if not, write to the Free Software Foundation,
00022  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
00023  *
00024  * ***** END GPL LICENSE BLOCK *****
00025  */
00026 
00032 #include "AUD_SilenceReader.h"
00033 
00034 #include <cstring>
00035 
00036 AUD_SilenceReader::AUD_SilenceReader() :
00037         m_position(0)
00038 {
00039 }
00040 
00041 bool AUD_SilenceReader::isSeekable() const
00042 {
00043         return true;
00044 }
00045 
00046 void AUD_SilenceReader::seek(int position)
00047 {
00048         m_position = position;
00049 }
00050 
00051 int AUD_SilenceReader::getLength() const
00052 {
00053         return -1;
00054 }
00055 
00056 int AUD_SilenceReader::getPosition() const
00057 {
00058         return m_position;
00059 }
00060 
00061 AUD_Specs AUD_SilenceReader::getSpecs() const
00062 {
00063         AUD_Specs specs;
00064         specs.rate = AUD_RATE_44100;
00065         specs.channels = AUD_CHANNELS_MONO;
00066         return specs;
00067 }
00068 
00069 void AUD_SilenceReader::read(int & length, sample_t* & buffer)
00070 {
00071         // resize if necessary
00072         if(m_buffer.getSize() < length * sizeof(sample_t))
00073         {
00074                 m_buffer.resize(length * sizeof(sample_t));
00075                 memset(m_buffer.getBuffer(), 0, m_buffer.getSize());
00076         }
00077 
00078         buffer = m_buffer.getBuffer();
00079         m_position += length;
00080 }