// NeL - MMORPG Framework
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program 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 Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see .
#include "stdsound.h"
#include "sample_bank_manager.h"
// STL includes
// NeL includes
// #include
#include
#include
// 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; igetArrayNode(&virtualBank, i);
if (virtualBank != 0)
{
std::vector 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; jgetArrayNode(&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 > &result)
{
result.clear();
TSampleBankContainer::iterator first(m_Banks.begin()), last(m_Banks.end());
for (; first != last; ++first)
{
std::pair 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 */