/** * 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 * . */ #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 */