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