khanat-opennel-code/code/nel/src/sound/sample_bank_manager.cpp
2010-05-06 02:08:41 +02:00

187 lines
4.5 KiB
C++

/**
* CSampleBankManager
* $Id: sample_bank_manager.cpp 2330 2010-03-08 23:14:04Z kaetemi $
* \file sample_bank_manager.cpp
* \brief CSampleBankManager
* \date 2010-03-08 21:09GMT
*/
/*
* Copyright (C) 2001-2010 by authors
*
* This file is part of NEVRAX NEL.
* NEVRAX NEL is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published
* by the Free Software Foundation, either version 2 of the License,
* or (at your option) any later version.
*
* NEVRAX NEL is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with NEVRAX NEL; see the file COPYING. If not, see
* <http://www.gnu.org/licenses/>.
*/
#include "stdsound.h"
#include "sample_bank_manager.h"
// STL includes
// NeL includes
// #include <nel/misc/debug.h>
#include <nel/misc/path.h>
#include <nel/misc/file.h>
// Project includes
#include "driver/sound_driver.h"
#include "driver/buffer.h"
#include "sample_bank.h"
#include "async_file_manager_sound.h"
#include "background_sound_manager.h"
#include "sound_bank.h"
using namespace std;
using namespace NLMISC;
namespace NLSOUND {
CSampleBankManager::CSampleBankManager(CAudioMixerUser *audioMixer) : m_AudioMixer(audioMixer), m_LoadedSize(NULL)
{
}
CSampleBankManager::~CSampleBankManager()
{
releaseAll();
}
void CSampleBankManager::init(NLGEORGES::UFormElm *mixerConfig)
{
if (mixerConfig == 0)
return;
NLGEORGES::UFormElm *virtualBanks;
mixerConfig->getNodeByName(&virtualBanks, ".VirtualBanks");
if (virtualBanks == 0)
return;
uint size;
virtualBanks->getArraySize(size);
for (uint i=0; i<size; ++i)
{
NLGEORGES::UFormElm *virtualBank;
virtualBanks->getArrayNode(&virtualBank, i);
if (virtualBank != 0)
{
std::vector<TFilteredBank> vfb;
std::string virtualName;
virtualBank->getValueByName(virtualName, ".VirtualName");
NLGEORGES::UFormElm *realBanks;
virtualBank->getNodeByName(&realBanks, ".FilteredBank");
if (realBanks != 0)
{
uint size2;
realBanks->getArraySize(size2);
for (uint j=0; j<size2; ++j)
{
TFilteredBank fb;
std::string bankName;
NLGEORGES::UFormElm *realBank;
realBank->getArrayNode(&realBank, j);
realBank->getValueByName(bankName, ".SampleBank");
fb.BankName = CStringMapper::map(bankName);
realBank->getValueByName(fb.Filter, ".Filter");
vfb.push_back(fb);
}
}
if (!vfb.empty())
{
TStringId virtualNameId = CStringMapper::map(virtualName);
m_VirtualBanks.insert(std::make_pair(virtualNameId, vfb));
// create the sample bank
CSampleBank *sampleBank = new CSampleBank(virtualNameId, this);
}
}
}
}
void CSampleBankManager::releaseAll()
{
// nldebug("SampleBanks: Releasing...");
while (!m_Banks.empty())
{
delete m_Banks.begin()->second;
}
// nldebug("SampleBanks: Released");
}
CSampleBank *CSampleBankManager::findSampleBank(const NLMISC::TStringId &filename)
{
TSampleBankContainer::iterator it(m_Banks.find(filename));
if (it != m_Banks.end())
return it->second;
return NULL;
}
IBuffer *CSampleBankManager::get(const NLMISC::TStringId &name)
{
IBuffer* buffer;
TSampleBankContainer::iterator iter;
for (iter = m_Banks.begin(); iter != m_Banks.end(); ++iter)
{
buffer = iter->second->getSample(name);
if (buffer != 0)
{
return buffer;
}
}
//nlwarning ("Try to get an unknown sample '%s'", name);
return 0;
}
void CSampleBankManager::reload(bool async)
{
TSampleBankContainer::iterator first(m_Banks.begin()), last(m_Banks.end());
for (; first != last; ++first)
{
first->second->unload();
first->second->load(async);
}
}
void CSampleBankManager::getLoadedSampleBankInfo(std::vector<std::pair<std::string, uint> > &result)
{
result.clear();
TSampleBankContainer::iterator first(m_Banks.begin()), last(m_Banks.end());
for (; first != last; ++first)
{
std::pair<std::string, uint> p;
if (first->second->isLoaded())
{
p.first = NLMISC::CStringMapper::unmap(first->first);
p.second = first->second->getSize();
result.push_back(p);
}
}
}
} /* namespace NLSOUND */
/* end of file */