609 |
uint16_t iSampleGroup = 0; // 0 refers to default sample group |
uint16_t iSampleGroup = 0; // 0 refers to default sample group |
610 |
File* pFile = static_cast<File*>(pParent); |
File* pFile = static_cast<File*>(pParent); |
611 |
if (pFile->pGroups) { |
if (pFile->pGroups) { |
612 |
std::list<Group*>::iterator iter = pFile->pGroups->begin(); |
std::vector<Group*>::iterator iter = pFile->pGroups->begin(); |
613 |
std::list<Group*>::iterator end = pFile->pGroups->end(); |
std::vector<Group*>::iterator end = pFile->pGroups->end(); |
614 |
for (int i = 0; iter != end; i++, iter++) { |
for (int i = 0; iter != end; i++, iter++) { |
615 |
if (*iter == pGroup) { |
if (*iter == pGroup) { |
616 |
iSampleGroup = i; |
iSampleGroup = i; |
1346 |
|
|
1347 |
// if this is the last write, update the checksum chunk in the |
// if this is the last write, update the checksum chunk in the |
1348 |
// file |
// file |
1349 |
if (pCkData->GetPos() == pCkData->GetSize()) { |
if (pCkData->GetPos() == std::min(pCkData->GetSize(), pCkData->GetNewSize())) { |
1350 |
__finalizeCRC(crc); |
__finalizeCRC(crc); |
1351 |
File* pFile = static_cast<File*>(GetParent()); |
File* pFile = static_cast<File*>(GetParent()); |
1352 |
pFile->SetSampleChecksum(this, crc); |
pFile->SetSampleChecksum(this, crc); |
4801 |
|
|
4802 |
ScriptGroup::~ScriptGroup() { |
ScriptGroup::~ScriptGroup() { |
4803 |
if (pScripts) { |
if (pScripts) { |
4804 |
std::list<Script*>::iterator iter = pScripts->begin(); |
std::vector<Script*>::iterator iter = pScripts->begin(); |
4805 |
std::list<Script*>::iterator end = pScripts->end(); |
std::vector<Script*>::iterator end = pScripts->end(); |
4806 |
while (iter != end) { |
while (iter != end) { |
4807 |
delete *iter; |
delete *iter; |
4808 |
++iter; |
++iter; |
4840 |
// now store the name of this group as <LSNM> chunk as subchunk of the <RTIS> list chunk |
// now store the name of this group as <LSNM> chunk as subchunk of the <RTIS> list chunk |
4841 |
::SaveString(CHUNK_ID_LSNM, NULL, pList, Name, String("Unnamed Group"), true, 64); |
::SaveString(CHUNK_ID_LSNM, NULL, pList, Name, String("Unnamed Group"), true, 64); |
4842 |
|
|
4843 |
for (std::list<Script*>::iterator it = pScripts->begin(); |
for (std::vector<Script*>::iterator it = pScripts->begin(); |
4844 |
it != pScripts->end(); ++it) |
it != pScripts->end(); ++it) |
4845 |
{ |
{ |
4846 |
(*it)->UpdateChunks(pProgress); |
(*it)->UpdateChunks(pProgress); |
4855 |
* @param index - number of the sought script (0..n) |
* @param index - number of the sought script (0..n) |
4856 |
* @returns sought script or NULL if there's no such script |
* @returns sought script or NULL if there's no such script |
4857 |
*/ |
*/ |
4858 |
Script* ScriptGroup::GetScript(uint index) { |
Script* ScriptGroup::GetScript(size_t index) { |
4859 |
if (!pScripts) LoadScripts(); |
if (!pScripts) LoadScripts(); |
4860 |
std::list<Script*>::iterator it = pScripts->begin(); |
if (index >= pScripts->size()) return NULL; |
4861 |
for (uint i = 0; it != pScripts->end(); ++i, ++it) |
return (*pScripts)[index]; |
|
if (i == index) return *it; |
|
|
return NULL; |
|
4862 |
} |
} |
4863 |
|
|
4864 |
/** @brief Add new instrument script. |
/** @brief Add new instrument script. |
4891 |
*/ |
*/ |
4892 |
void ScriptGroup::DeleteScript(Script* pScript) { |
void ScriptGroup::DeleteScript(Script* pScript) { |
4893 |
if (!pScripts) LoadScripts(); |
if (!pScripts) LoadScripts(); |
4894 |
std::list<Script*>::iterator iter = |
std::vector<Script*>::iterator iter = |
4895 |
find(pScripts->begin(), pScripts->end(), pScript); |
find(pScripts->begin(), pScripts->end(), pScript); |
4896 |
if (iter == pScripts->end()) |
if (iter == pScripts->end()) |
4897 |
throw gig::Exception("Could not delete script, could not find given script"); |
throw gig::Exception("Could not delete script, could not find given script"); |
4904 |
|
|
4905 |
void ScriptGroup::LoadScripts() { |
void ScriptGroup::LoadScripts() { |
4906 |
if (pScripts) return; |
if (pScripts) return; |
4907 |
pScripts = new std::list<Script*>; |
pScripts = new std::vector<Script*>; |
4908 |
if (!pList) return; |
if (!pList) return; |
4909 |
|
|
4910 |
size_t i = 0; |
size_t i = 0; |
5308 |
* @param pos - position of sought Region in region list |
* @param pos - position of sought Region in region list |
5309 |
* @returns pointer address to requested region or @c NULL if @a pos is |
* @returns pointer address to requested region or @c NULL if @a pos is |
5310 |
* out of bounds |
* out of bounds |
5311 |
|
* @see CountRegions() |
5312 |
*/ |
*/ |
5313 |
Region* Instrument::GetRegionAt(size_t pos) { |
Region* Instrument::GetRegionAt(size_t pos) { |
5314 |
if (!pRegions) return NULL; |
if (!pRegions) return NULL; |
5353 |
if (!lrgn) lrgn = pCkInstrument->AddSubList(LIST_TYPE_LRGN); |
if (!lrgn) lrgn = pCkInstrument->AddSubList(LIST_TYPE_LRGN); |
5354 |
RIFF::List* rgn = lrgn->AddSubList(LIST_TYPE_RGN); |
RIFF::List* rgn = lrgn->AddSubList(LIST_TYPE_RGN); |
5355 |
Region* pNewRegion = new Region(this, rgn); |
Region* pNewRegion = new Region(this, rgn); |
5356 |
|
const size_t idxIt = RegionsIterator - pRegions->begin(); |
5357 |
pRegions->push_back(pNewRegion); |
pRegions->push_back(pNewRegion); |
5358 |
|
RegionsIterator = pRegions->begin() + std::min(idxIt, pRegions->size()); // avoid iterator invalidation |
5359 |
Regions = (uint32_t) pRegions->size(); |
Regions = (uint32_t) pRegions->size(); |
5360 |
// update Region key table for fast lookup |
// update Region key table for fast lookup |
5361 |
UpdateRegionKeyTable(); |
UpdateRegionKeyTable(); |
5395 |
* @param dst - destination instrument at which this instrument will be |
* @param dst - destination instrument at which this instrument will be |
5396 |
* moved to, or pass NULL for moving to end of list |
* moved to, or pass NULL for moving to end of list |
5397 |
* @throw gig::Exception if this instrument and target instrument are not |
* @throw gig::Exception if this instrument and target instrument are not |
5398 |
* part of the same file |
* part of the same file, as well as on unexpected |
5399 |
|
* internal error |
5400 |
*/ |
*/ |
5401 |
void Instrument::MoveTo(Instrument* dst) { |
void Instrument::MoveTo(Instrument* dst) { |
5402 |
if (dst && GetParent() != dst->GetParent()) |
if (dst && GetParent() != dst->GetParent()) |
5413 |
|
|
5414 |
File::InstrumentList::iterator itFrom = |
File::InstrumentList::iterator itFrom = |
5415 |
std::find(list.begin(), list.end(), static_cast<DLS::Instrument*>(this)); |
std::find(list.begin(), list.end(), static_cast<DLS::Instrument*>(this)); |
5416 |
|
if (itFrom == list.end()) |
5417 |
|
throw Exception( |
5418 |
|
"gig::Instrument::MoveTo(): unexpected missing membership " |
5419 |
|
"of this instrument." |
5420 |
|
); |
5421 |
|
list.erase(itFrom); |
5422 |
|
|
5423 |
File::InstrumentList::iterator itTo = |
File::InstrumentList::iterator itTo = |
5424 |
std::find(list.begin(), list.end(), static_cast<DLS::Instrument*>(dst)); |
std::find(list.begin(), list.end(), static_cast<DLS::Instrument*>(dst)); |
5425 |
|
|
5426 |
list.splice(itTo, list, itFrom); |
list.insert(itTo, this); |
5427 |
} |
} |
5428 |
|
|
5429 |
// move the instrument's actual list RIFF chunk appropriately |
// move the instrument's actual list RIFF chunk appropriately |
5504 |
File* pFile = (File*) GetParent(); |
File* pFile = (File*) GetParent(); |
5505 |
for (uint k = 0; k < scriptPoolFileOffsets.size(); ++k) { |
for (uint k = 0; k < scriptPoolFileOffsets.size(); ++k) { |
5506 |
uint32_t soughtOffset = scriptPoolFileOffsets[k].fileOffset; |
uint32_t soughtOffset = scriptPoolFileOffsets[k].fileOffset; |
5507 |
for (uint i = 0; pFile->GetScriptGroup(i); ++i) { |
for (size_t i = 0; pFile->GetScriptGroup(i); ++i) { |
5508 |
ScriptGroup* group = pFile->GetScriptGroup(i); |
ScriptGroup* group = pFile->GetScriptGroup(i); |
5509 |
for (uint s = 0; group->GetScript(s); ++s) { |
for (uint s = 0; group->GetScript(s); ++s) { |
5510 |
Script* script = group->GetScript(s); |
Script* script = group->GetScript(s); |
5542 |
* @param index - instrument script slot index |
* @param index - instrument script slot index |
5543 |
* @returns script or NULL if index is out of bounds |
* @returns script or NULL if index is out of bounds |
5544 |
*/ |
*/ |
5545 |
Script* Instrument::GetScriptOfSlot(uint index) { |
Script* Instrument::GetScriptOfSlot(size_t index) { |
5546 |
LoadScripts(); |
LoadScripts(); |
5547 |
if (index >= pScriptRefs->size()) return NULL; |
if (index >= pScriptRefs->size()) return NULL; |
5548 |
return pScriptRefs->at(index).script; |
return pScriptRefs->at(index).script; |
5603 |
* @param index1 - index of the first script slot to swap |
* @param index1 - index of the first script slot to swap |
5604 |
* @param index2 - index of the second script slot to swap |
* @param index2 - index of the second script slot to swap |
5605 |
*/ |
*/ |
5606 |
void Instrument::SwapScriptSlots(uint index1, uint index2) { |
void Instrument::SwapScriptSlots(size_t index1, size_t index2) { |
5607 |
LoadScripts(); |
LoadScripts(); |
5608 |
if (index1 >= pScriptRefs->size() || index2 >= pScriptRefs->size()) |
if (index1 >= pScriptRefs->size() || index2 >= pScriptRefs->size()) |
5609 |
return; |
return; |
5618 |
* |
* |
5619 |
* @param index - index of script slot to remove |
* @param index - index of script slot to remove |
5620 |
*/ |
*/ |
5621 |
void Instrument::RemoveScriptSlot(uint index) { |
void Instrument::RemoveScriptSlot(size_t index) { |
5622 |
LoadScripts(); |
LoadScripts(); |
5623 |
if (index >= pScriptRefs->size()) return; |
if (index >= pScriptRefs->size()) return; |
5624 |
pScriptRefs->erase( pScriptRefs->begin() + index ); |
pScriptRefs->erase( pScriptRefs->begin() + index ); |
5659 |
* GigaStudio 4 software. It will currently only work with LinuxSampler and |
* GigaStudio 4 software. It will currently only work with LinuxSampler and |
5660 |
* gigedit. |
* gigedit. |
5661 |
*/ |
*/ |
5662 |
uint Instrument::ScriptSlotCount() const { |
size_t Instrument::ScriptSlotCount() const { |
5663 |
return uint(pScriptRefs ? pScriptRefs->size() : scriptPoolFileOffsets.size()); |
return pScriptRefs ? pScriptRefs->size() : scriptPoolFileOffsets.size(); |
5664 |
} |
} |
5665 |
|
|
5666 |
/** @brief Whether script execution shall be skipped. |
/** @brief Whether script execution shall be skipped. |
5679 |
* @param index - index of the script slot on this instrument |
* @param index - index of the script slot on this instrument |
5680 |
* @see Script::Bypass |
* @see Script::Bypass |
5681 |
*/ |
*/ |
5682 |
bool Instrument::IsScriptSlotBypassed(uint index) { |
bool Instrument::IsScriptSlotBypassed(size_t index) { |
5683 |
if (index >= ScriptSlotCount()) return false; |
if (index >= ScriptSlotCount()) return false; |
5684 |
return pScriptRefs ? pScriptRefs->at(index).bypass |
return pScriptRefs ? pScriptRefs->at(index).bypass |
5685 |
: scriptPoolFileOffsets.at(index).bypass; |
: scriptPoolFileOffsets.at(index).bypass; |
5699 |
* @param bBypass - if true, the script slot will be skipped by the sampler |
* @param bBypass - if true, the script slot will be skipped by the sampler |
5700 |
* @see Script::Bypass |
* @see Script::Bypass |
5701 |
*/ |
*/ |
5702 |
void Instrument::SetScriptSlotBypassed(uint index, bool bBypass) { |
void Instrument::SetScriptSlotBypassed(size_t index, bool bBypass) { |
5703 |
if (index >= ScriptSlotCount()) return; |
if (index >= ScriptSlotCount()) return; |
5704 |
if (pScriptRefs) |
if (pScriptRefs) |
5705 |
pScriptRefs->at(index).bypass = bBypass; |
pScriptRefs->at(index).bypass = bBypass; |
5719 |
* the @c Script identified by passed @p uuid. |
* the @c Script identified by passed @p uuid. |
5720 |
*/ |
*/ |
5721 |
bool Instrument::ReferencesScriptWithUuid(const _UUID& uuid) { |
bool Instrument::ReferencesScriptWithUuid(const _UUID& uuid) { |
5722 |
const uint nSlots = ScriptSlotCount(); |
const size_t nSlots = ScriptSlotCount(); |
5723 |
for (uint iSlot = 0; iSlot < nSlots; ++iSlot) |
for (size_t iSlot = 0; iSlot < nSlots; ++iSlot) |
5724 |
if (_UUIDFromCArray(&GetScriptOfSlot(iSlot)->Uuid[0]) == uuid) |
if (_UUIDFromCArray(&GetScriptOfSlot(iSlot)->Uuid[0]) == uuid) |
5725 |
return true; |
return true; |
5726 |
return false; |
return false; |
5745 |
* @param slot - script slot index of the variable to be retrieved |
* @param slot - script slot index of the variable to be retrieved |
5746 |
* @param variable - name of the 'patch' variable in that script |
* @param variable - name of the 'patch' variable in that script |
5747 |
*/ |
*/ |
5748 |
bool Instrument::IsScriptPatchVariableSet(int slot, String variable) { |
bool Instrument::IsScriptPatchVariableSet(size_t slot, String variable) { |
5749 |
if (variable.empty()) return false; |
if (variable.empty()) return false; |
5750 |
Script* script = GetScriptOfSlot(slot); |
Script* script = GetScriptOfSlot(slot); |
5751 |
if (!script) return false; |
if (!script) return false; |
5779 |
* |
* |
5780 |
* @param slot - script slot index of the variable to be retrieved |
* @param slot - script slot index of the variable to be retrieved |
5781 |
*/ |
*/ |
5782 |
std::map<String,String> Instrument::GetScriptPatchVariables(int slot) { |
std::map<String,String> Instrument::GetScriptPatchVariables(size_t slot) { |
5783 |
Script* script = GetScriptOfSlot(slot); |
Script* script = GetScriptOfSlot(slot); |
5784 |
if (!script) return std::map<String,String>(); |
if (!script) return std::map<String,String>(); |
5785 |
const _UUID uuid = _UUIDFromCArray(&script->Uuid[0]); |
const _UUID uuid = _UUIDFromCArray(&script->Uuid[0]); |
5811 |
* @param slot - script slot index of the variable to be retrieved |
* @param slot - script slot index of the variable to be retrieved |
5812 |
* @param variable - name of the 'patch' variable in that script |
* @param variable - name of the 'patch' variable in that script |
5813 |
*/ |
*/ |
5814 |
String Instrument::GetScriptPatchVariable(int slot, String variable) { |
String Instrument::GetScriptPatchVariable(size_t slot, String variable) { |
5815 |
std::map<String,String> vars = GetScriptPatchVariables(slot); |
std::map<String,String> vars = GetScriptPatchVariables(slot); |
5816 |
return (vars.count(variable)) ? vars.find(variable)->second : ""; |
return (vars.count(variable)) ? vars.find(variable)->second : ""; |
5817 |
} |
} |
5838 |
* @throws gig::Exception if given script @p slot index is invalid or given |
* @throws gig::Exception if given script @p slot index is invalid or given |
5839 |
* @p variable name is empty |
* @p variable name is empty |
5840 |
*/ |
*/ |
5841 |
void Instrument::SetScriptPatchVariable(int slot, String variable, String value) { |
void Instrument::SetScriptPatchVariable(size_t slot, String variable, String value) { |
5842 |
if (variable.empty()) |
if (variable.empty()) |
5843 |
throw Exception("Variable name must not be empty"); |
throw Exception("Variable name must not be empty"); |
5844 |
Script* script = GetScriptOfSlot(slot); |
Script* script = GetScriptOfSlot(slot); |
5879 |
* @param slot - script slot index of the variable to be unset |
* @param slot - script slot index of the variable to be unset |
5880 |
* @param variable - name of the 'patch' variable in that script |
* @param variable - name of the 'patch' variable in that script |
5881 |
*/ |
*/ |
5882 |
void Instrument::UnsetScriptPatchVariable(int slot, String variable) { |
void Instrument::UnsetScriptPatchVariable(ssize_t slot, String variable) { |
5883 |
Script* script = GetScriptOfSlot(slot); |
Script* script = GetScriptOfSlot(slot); |
5884 |
|
|
5885 |
// option 1: unset a particular variable of one particular script slot |
// option 1: unset a particular variable of one particular script slot |
6212 |
*/ |
*/ |
6213 |
void Group::MoveAll() { |
void Group::MoveAll() { |
6214 |
// get "that" other group first |
// get "that" other group first |
6215 |
|
size_t i = 0; |
6216 |
Group* pOtherGroup = NULL; |
Group* pOtherGroup = NULL; |
6217 |
for (pOtherGroup = pFile->GetFirstGroup(); pOtherGroup; pOtherGroup = pFile->GetNextGroup()) { |
for (pOtherGroup = pFile->GetGroup(i); pOtherGroup; |
6218 |
|
pOtherGroup = pFile->GetGroup(++i)) |
6219 |
|
{ |
6220 |
if (pOtherGroup != this) break; |
if (pOtherGroup != this) break; |
6221 |
} |
} |
6222 |
if (!pOtherGroup) throw Exception( |
if (!pOtherGroup) throw Exception( |
6297 |
|
|
6298 |
File::~File() { |
File::~File() { |
6299 |
if (pGroups) { |
if (pGroups) { |
6300 |
std::list<Group*>::iterator iter = pGroups->begin(); |
std::vector<Group*>::iterator iter = pGroups->begin(); |
6301 |
std::list<Group*>::iterator end = pGroups->end(); |
std::vector<Group*>::iterator end = pGroups->end(); |
6302 |
while (iter != end) { |
while (iter != end) { |
6303 |
delete *iter; |
delete *iter; |
6304 |
++iter; |
++iter; |
6306 |
delete pGroups; |
delete pGroups; |
6307 |
} |
} |
6308 |
if (pScriptGroups) { |
if (pScriptGroups) { |
6309 |
std::list<ScriptGroup*>::iterator iter = pScriptGroups->begin(); |
std::vector<ScriptGroup*>::iterator iter = pScriptGroups->begin(); |
6310 |
std::list<ScriptGroup*>::iterator end = pScriptGroups->end(); |
std::vector<ScriptGroup*>::iterator end = pScriptGroups->end(); |
6311 |
while (iter != end) { |
while (iter != end) { |
6312 |
delete *iter; |
delete *iter; |
6313 |
++iter; |
++iter; |
6391 |
wave->AddSubChunk(CHUNK_ID_FMT, 16); |
wave->AddSubChunk(CHUNK_ID_FMT, 16); |
6392 |
wave->AddSubList(LIST_TYPE_INFO); |
wave->AddSubList(LIST_TYPE_INFO); |
6393 |
|
|
6394 |
|
const size_t idxIt = SamplesIterator - pSamples->begin(); |
6395 |
pSamples->push_back(pSample); |
pSamples->push_back(pSample); |
6396 |
|
SamplesIterator = pSamples->begin() + std::min(idxIt, pSamples->size()); // avoid iterator invalidation |
6397 |
return pSample; |
return pSample; |
6398 |
} |
} |
6399 |
|
|
6410 |
if (!pSamples || !pSamples->size()) throw gig::Exception("Could not delete sample as there are no samples"); |
if (!pSamples || !pSamples->size()) throw gig::Exception("Could not delete sample as there are no samples"); |
6411 |
SampleList::iterator iter = find(pSamples->begin(), pSamples->end(), (DLS::Sample*) pSample); |
SampleList::iterator iter = find(pSamples->begin(), pSamples->end(), (DLS::Sample*) pSample); |
6412 |
if (iter == pSamples->end()) throw gig::Exception("Could not delete sample, could not find given sample"); |
if (iter == pSamples->end()) throw gig::Exception("Could not delete sample, could not find given sample"); |
6413 |
if (SamplesIterator != pSamples->end() && *SamplesIterator == pSample) ++SamplesIterator; // avoid iterator invalidation |
const size_t idxIt = SamplesIterator - pSamples->begin(); |
6414 |
pSamples->erase(iter); |
pSamples->erase(iter); |
6415 |
|
SamplesIterator = pSamples->begin() + std::min(idxIt, pSamples->size()); // avoid iterator invalidation |
6416 |
pSample->DeleteChunks(); |
pSample->DeleteChunks(); |
6417 |
delete pSample; |
delete pSample; |
6418 |
|
|
|
SampleList::iterator tmp = SamplesIterator; |
|
6419 |
// remove all references to the sample |
// remove all references to the sample |
6420 |
for (Instrument* instrument = GetFirstInstrument() ; instrument ; |
size_t iIns = 0; |
6421 |
instrument = GetNextInstrument()) { |
for (Instrument* instrument = GetInstrument(iIns); instrument; |
6422 |
|
instrument = GetInstrument(++iIns)) |
6423 |
|
{ |
6424 |
size_t iRgn = 0; |
size_t iRgn = 0; |
6425 |
for (Region* region = instrument->GetRegionAt(iRgn); region; |
for (Region* region = instrument->GetRegionAt(iRgn); region; |
6426 |
region = instrument->GetRegionAt(++iRgn)) |
region = instrument->GetRegionAt(++iRgn)) |
6433 |
} |
} |
6434 |
} |
} |
6435 |
} |
} |
|
SamplesIterator = tmp; // restore iterator |
|
6436 |
} |
} |
6437 |
|
|
6438 |
void File::LoadSamples() { |
void File::LoadSamples() { |
6519 |
ExtensionFiles.push_back(pExtFile); |
ExtensionFiles.push_back(pExtFile); |
6520 |
} |
} |
6521 |
|
|
6522 |
// load samples from extension files (if required) |
// load all samples (both from this/main .gig file as well as from |
6523 |
|
// extension files if required) |
6524 |
for (int i = 0; i < poolFiles.size(); i++) { |
for (int i = 0; i < poolFiles.size(); i++) { |
6525 |
RIFF::File* file = poolFiles[i]; |
RIFF::File* file = poolFiles[i]; |
6526 |
RIFF::List* wvpl = file->GetSubList(LIST_TYPE_WVPL); |
RIFF::List* wvpl = file->GetSubList(LIST_TYPE_WVPL); |
6527 |
if (wvpl) { |
if (wvpl) { |
6528 |
file_offset_t wvplFileOffset = wvpl->GetFilePos() - |
file_offset_t wvplFileOffset = wvpl->GetFilePos() - |
6529 |
wvpl->GetPos(); // should be zero, but just to be sure |
wvpl->GetPos(); // should be zero, but just to be sure |
6530 |
size_t i = 0; |
size_t iWaveCk = 0; |
6531 |
for (RIFF::List* wave = wvpl->GetSubListAt(i); wave; |
for (RIFF::List* wave = wvpl->GetSubListAt(iWaveCk); wave; |
6532 |
wave = wvpl->GetSubListAt(++i)) |
wave = wvpl->GetSubListAt(++iWaveCk)) |
6533 |
{ |
{ |
6534 |
if (wave->GetListType() == LIST_TYPE_WAVE) { |
if (wave->GetListType() == LIST_TYPE_WAVE) { |
6535 |
// notify current progress |
// notify current progress |
6551 |
__notify_progress(pProgress, 1.0); // notify done |
__notify_progress(pProgress, 1.0); // notify done |
6552 |
} |
} |
6553 |
|
|
6554 |
|
/** |
6555 |
|
* Returns a pointer to the first <i>Instrument</i> object of the file, |
6556 |
|
* <i>NULL</i> otherwise. |
6557 |
|
* |
6558 |
|
* @deprecated This method is not reentrant-safe, use GetInstrument() |
6559 |
|
* instead. |
6560 |
|
*/ |
6561 |
Instrument* File::GetFirstInstrument() { |
Instrument* File::GetFirstInstrument() { |
6562 |
if (!pInstruments) LoadInstruments(); |
if (!pInstruments) LoadInstruments(); |
6563 |
if (!pInstruments) return NULL; |
if (!pInstruments) return NULL; |
6565 |
return static_cast<gig::Instrument*>( (InstrumentsIterator != pInstruments->end()) ? *InstrumentsIterator : NULL ); |
return static_cast<gig::Instrument*>( (InstrumentsIterator != pInstruments->end()) ? *InstrumentsIterator : NULL ); |
6566 |
} |
} |
6567 |
|
|
6568 |
|
/** |
6569 |
|
* Returns a pointer to the next <i>Instrument</i> object of the file, |
6570 |
|
* <i>NULL</i> otherwise. |
6571 |
|
* |
6572 |
|
* @deprecated This method is not reentrant-safe, use GetInstrument() |
6573 |
|
* instead. |
6574 |
|
*/ |
6575 |
Instrument* File::GetNextInstrument() { |
Instrument* File::GetNextInstrument() { |
6576 |
if (!pInstruments) return NULL; |
if (!pInstruments) return NULL; |
6577 |
InstrumentsIterator++; |
InstrumentsIterator++; |
6599 |
* @param pProgress - optional: callback function for progress notification |
* @param pProgress - optional: callback function for progress notification |
6600 |
* @returns sought instrument or NULL if there's no such instrument |
* @returns sought instrument or NULL if there's no such instrument |
6601 |
*/ |
*/ |
6602 |
Instrument* File::GetInstrument(uint index, progress_t* pProgress) { |
Instrument* File::GetInstrument(size_t index, progress_t* pProgress) { |
6603 |
if (!pInstruments) { |
if (!pInstruments) { |
6604 |
// TODO: hack - we simply load ALL samples here, it would have been done in the Region constructor anyway (ATM) |
// TODO: hack - we simply load ALL samples here, it would have been done in the Region constructor anyway (ATM) |
6605 |
|
|
6630 |
} |
} |
6631 |
} |
} |
6632 |
if (!pInstruments) return NULL; |
if (!pInstruments) return NULL; |
6633 |
InstrumentsIterator = pInstruments->begin(); |
if (index >= pInstruments->size()) return NULL; |
6634 |
for (uint i = 0; InstrumentsIterator != pInstruments->end(); i++) { |
return static_cast<gig::Instrument*>( (*pInstruments)[index] ); |
|
if (i == index) return static_cast<gig::Instrument*>( *InstrumentsIterator ); |
|
|
InstrumentsIterator++; |
|
|
} |
|
|
return NULL; |
|
6635 |
} |
} |
6636 |
|
|
6637 |
/** @brief Add a new instrument definition. |
/** @brief Add a new instrument definition. |
6659 |
// this string is needed for the gig to be loadable in GSt: |
// this string is needed for the gig to be loadable in GSt: |
6660 |
pInstrument->pInfo->Software = "Endless Wave"; |
pInstrument->pInfo->Software = "Endless Wave"; |
6661 |
|
|
6662 |
|
const size_t idxIt = InstrumentsIterator - pInstruments->begin(); |
6663 |
pInstruments->push_back(pInstrument); |
pInstruments->push_back(pInstrument); |
6664 |
|
InstrumentsIterator = pInstruments->begin() + std::min(idxIt, pInstruments->size()); // avoid iterator invalidation |
6665 |
return pInstrument; |
return pInstrument; |
6666 |
} |
} |
6667 |
|
|
6720 |
} |
} |
6721 |
|
|
6722 |
// clone script groups and their scripts |
// clone script groups and their scripts |
6723 |
for (int iGroup = 0; pFile->GetScriptGroup(iGroup); ++iGroup) { |
for (size_t iGroup = 0; pFile->GetScriptGroup(iGroup); ++iGroup) { |
6724 |
ScriptGroup* sg = pFile->GetScriptGroup(iGroup); |
ScriptGroup* sg = pFile->GetScriptGroup(iGroup); |
6725 |
ScriptGroup* dg = AddScriptGroup(); |
ScriptGroup* dg = AddScriptGroup(); |
6726 |
dg->Name = "COPY" + ToString(iCallCount) + "_" + sg->Name; |
dg->Name = "COPY" + ToString(iCallCount) + "_" + sg->Name; |
6773 |
if (!pInstruments) throw gig::Exception("Could not delete instrument as there are no instruments"); |
if (!pInstruments) throw gig::Exception("Could not delete instrument as there are no instruments"); |
6774 |
InstrumentList::iterator iter = find(pInstruments->begin(), pInstruments->end(), (DLS::Instrument*) pInstrument); |
InstrumentList::iterator iter = find(pInstruments->begin(), pInstruments->end(), (DLS::Instrument*) pInstrument); |
6775 |
if (iter == pInstruments->end()) throw gig::Exception("Could not delete instrument, could not find given instrument"); |
if (iter == pInstruments->end()) throw gig::Exception("Could not delete instrument, could not find given instrument"); |
6776 |
|
const size_t idxIt = InstrumentsIterator - pInstruments->begin(); |
6777 |
pInstruments->erase(iter); |
pInstruments->erase(iter); |
6778 |
|
InstrumentsIterator = pInstruments->begin() + std::min(idxIt, pInstruments->size()); // avoid iterator invalidation |
6779 |
pInstrument->DeleteChunks(); |
pInstrument->DeleteChunks(); |
6780 |
delete pInstrument; |
delete pInstrument; |
6781 |
} |
} |
6966 |
return bRequiresSave; |
return bRequiresSave; |
6967 |
} |
} |
6968 |
|
|
6969 |
|
/** |
6970 |
|
* Returns a pointer to the first <i>Group</i> object of the file, |
6971 |
|
* <i>NULL</i> otherwise. |
6972 |
|
* |
6973 |
|
* @deprecated This method is not reentrant-safe, use GetGroup() instead. |
6974 |
|
*/ |
6975 |
Group* File::GetFirstGroup() { |
Group* File::GetFirstGroup() { |
6976 |
if (!pGroups) LoadGroups(); |
if (!pGroups) LoadGroups(); |
6977 |
// there must always be at least one group |
// there must always be at least one group |
6979 |
return *GroupsIterator; |
return *GroupsIterator; |
6980 |
} |
} |
6981 |
|
|
6982 |
|
/** |
6983 |
|
* Returns a pointer to the next <i>Group</i> object of the file, |
6984 |
|
* <i>NULL</i> otherwise. |
6985 |
|
* |
6986 |
|
* @deprecated This method is not reentrant-safe, use GetGroup() instead. |
6987 |
|
*/ |
6988 |
Group* File::GetNextGroup() { |
Group* File::GetNextGroup() { |
6989 |
if (!pGroups) return NULL; |
if (!pGroups) return NULL; |
6990 |
++GroupsIterator; |
++GroupsIterator; |
6997 |
* @param index - number of the sought group (0..n) |
* @param index - number of the sought group (0..n) |
6998 |
* @returns sought group or NULL if there's no such group |
* @returns sought group or NULL if there's no such group |
6999 |
*/ |
*/ |
7000 |
Group* File::GetGroup(uint index) { |
Group* File::GetGroup(size_t index) { |
7001 |
if (!pGroups) LoadGroups(); |
if (!pGroups) LoadGroups(); |
7002 |
GroupsIterator = pGroups->begin(); |
if (index >= pGroups->size()) return NULL; |
7003 |
for (uint i = 0; GroupsIterator != pGroups->end(); i++) { |
return (*pGroups)[index]; |
|
if (i == index) return *GroupsIterator; |
|
|
++GroupsIterator; |
|
|
} |
|
|
return NULL; |
|
7004 |
} |
} |
7005 |
|
|
7006 |
/** |
/** |
7015 |
*/ |
*/ |
7016 |
Group* File::GetGroup(String name) { |
Group* File::GetGroup(String name) { |
7017 |
if (!pGroups) LoadGroups(); |
if (!pGroups) LoadGroups(); |
7018 |
GroupsIterator = pGroups->begin(); |
size_t i = 0; |
7019 |
for (uint i = 0; GroupsIterator != pGroups->end(); ++GroupsIterator, ++i) |
for (Group* pGroup = GetGroup(i); pGroup; pGroup = GetGroup(++i)) |
7020 |
if ((*GroupsIterator)->Name == name) return *GroupsIterator; |
if (pGroup->Name == name) return pGroup; |
7021 |
return NULL; |
return NULL; |
7022 |
} |
} |
7023 |
|
|
7041 |
*/ |
*/ |
7042 |
void File::DeleteGroup(Group* pGroup) { |
void File::DeleteGroup(Group* pGroup) { |
7043 |
if (!pGroups) LoadGroups(); |
if (!pGroups) LoadGroups(); |
7044 |
std::list<Group*>::iterator iter = find(pGroups->begin(), pGroups->end(), pGroup); |
std::vector<Group*>::iterator iter = |
7045 |
|
find(pGroups->begin(), pGroups->end(), pGroup); |
7046 |
if (iter == pGroups->end()) throw gig::Exception("Could not delete group, could not find given group"); |
if (iter == pGroups->end()) throw gig::Exception("Could not delete group, could not find given group"); |
7047 |
if (pGroups->size() == 1) throw gig::Exception("Cannot delete group, there must be at least one default group!"); |
if (pGroups->size() == 1) throw gig::Exception("Cannot delete group, there must be at least one default group!"); |
7048 |
// delete all members of this group |
// delete all members of this group |
7068 |
*/ |
*/ |
7069 |
void File::DeleteGroupOnly(Group* pGroup) { |
void File::DeleteGroupOnly(Group* pGroup) { |
7070 |
if (!pGroups) LoadGroups(); |
if (!pGroups) LoadGroups(); |
7071 |
std::list<Group*>::iterator iter = find(pGroups->begin(), pGroups->end(), pGroup); |
std::vector<Group*>::iterator iter = |
7072 |
|
find(pGroups->begin(), pGroups->end(), pGroup); |
7073 |
if (iter == pGroups->end()) throw gig::Exception("Could not delete group, could not find given group"); |
if (iter == pGroups->end()) throw gig::Exception("Could not delete group, could not find given group"); |
7074 |
if (pGroups->size() == 1) throw gig::Exception("Cannot delete group, there must be at least one default group!"); |
if (pGroups->size() == 1) throw gig::Exception("Cannot delete group, there must be at least one default group!"); |
7075 |
// move all members of this group to another group |
// move all members of this group to another group |
7080 |
} |
} |
7081 |
|
|
7082 |
void File::LoadGroups() { |
void File::LoadGroups() { |
7083 |
if (!pGroups) pGroups = new std::list<Group*>; |
if (!pGroups) pGroups = new std::vector<Group*>; |
7084 |
// try to read defined groups from file |
// try to read defined groups from file |
7085 |
RIFF::List* lst3gri = pRIFF->GetSubList(LIST_TYPE_3GRI); |
RIFF::List* lst3gri = pRIFF->GetSubList(LIST_TYPE_3GRI); |
7086 |
if (lst3gri) { |
if (lst3gri) { |
7114 |
* @param index - number of the sought group (0..n) |
* @param index - number of the sought group (0..n) |
7115 |
* @returns sought script group or NULL if there's no such group |
* @returns sought script group or NULL if there's no such group |
7116 |
*/ |
*/ |
7117 |
ScriptGroup* File::GetScriptGroup(uint index) { |
ScriptGroup* File::GetScriptGroup(size_t index) { |
7118 |
if (!pScriptGroups) LoadScriptGroups(); |
if (!pScriptGroups) LoadScriptGroups(); |
7119 |
std::list<ScriptGroup*>::iterator it = pScriptGroups->begin(); |
if (index >= pScriptGroups->size()) return NULL; |
7120 |
for (uint i = 0; it != pScriptGroups->end(); ++i, ++it) |
return (*pScriptGroups)[index]; |
|
if (i == index) return *it; |
|
|
return NULL; |
|
7121 |
} |
} |
7122 |
|
|
7123 |
/** @brief Get instrument script group (by name). |
/** @brief Get instrument script group (by name). |
7130 |
*/ |
*/ |
7131 |
ScriptGroup* File::GetScriptGroup(const String& name) { |
ScriptGroup* File::GetScriptGroup(const String& name) { |
7132 |
if (!pScriptGroups) LoadScriptGroups(); |
if (!pScriptGroups) LoadScriptGroups(); |
7133 |
std::list<ScriptGroup*>::iterator it = pScriptGroups->begin(); |
for (size_t i = 0; i < pScriptGroups->size(); ++i) { |
7134 |
for (uint i = 0; it != pScriptGroups->end(); ++i, ++it) |
ScriptGroup* pGroup = (*pScriptGroups)[i]; |
7135 |
if ((*it)->Name == name) return *it; |
if (pGroup->Name == name) return pGroup; |
7136 |
|
} |
7137 |
return NULL; |
return NULL; |
7138 |
} |
} |
7139 |
|
|
7166 |
*/ |
*/ |
7167 |
void File::DeleteScriptGroup(ScriptGroup* pScriptGroup) { |
void File::DeleteScriptGroup(ScriptGroup* pScriptGroup) { |
7168 |
if (!pScriptGroups) LoadScriptGroups(); |
if (!pScriptGroups) LoadScriptGroups(); |
7169 |
std::list<ScriptGroup*>::iterator iter = |
std::vector<ScriptGroup*>::iterator iter = |
7170 |
find(pScriptGroups->begin(), pScriptGroups->end(), pScriptGroup); |
find(pScriptGroups->begin(), pScriptGroups->end(), pScriptGroup); |
7171 |
if (iter == pScriptGroups->end()) |
if (iter == pScriptGroups->end()) |
7172 |
throw gig::Exception("Could not delete script group, could not find given script group"); |
throw gig::Exception("Could not delete script group, could not find given script group"); |
7181 |
|
|
7182 |
void File::LoadScriptGroups() { |
void File::LoadScriptGroups() { |
7183 |
if (pScriptGroups) return; |
if (pScriptGroups) return; |
7184 |
pScriptGroups = new std::list<ScriptGroup*>; |
pScriptGroups = new std::vector<ScriptGroup*>; |
7185 |
RIFF::List* lstLS = pRIFF->GetSubList(LIST_TYPE_3LS); |
RIFF::List* lstLS = pRIFF->GetSubList(LIST_TYPE_3LS); |
7186 |
if (lstLS) { |
if (lstLS) { |
7187 |
size_t i = 0; |
size_t i = 0; |
7226 |
// of the respective instrument script chunk as reference. |
// of the respective instrument script chunk as reference. |
7227 |
if (pScriptGroups) { |
if (pScriptGroups) { |
7228 |
// Update instrument script (group) chunks. |
// Update instrument script (group) chunks. |
7229 |
for (std::list<ScriptGroup*>::iterator it = pScriptGroups->begin(); |
for (std::vector<ScriptGroup*>::iterator it = pScriptGroups->begin(); |
7230 |
it != pScriptGroups->end(); ++it) |
it != pScriptGroups->end(); ++it) |
7231 |
{ |
{ |
7232 |
(*it)->UpdateChunks(pProgress); |
(*it)->UpdateChunks(pProgress); |
7278 |
} |
} |
7279 |
} |
} |
7280 |
|
|
7281 |
std::list<Group*>::iterator iter = pGroups->begin(); |
std::vector<Group*>::iterator iter = pGroups->begin(); |
7282 |
std::list<Group*>::iterator end = pGroups->end(); |
std::vector<Group*>::iterator end = pGroups->end(); |
7283 |
for (; iter != end; ++iter) { |
for (; iter != end; ++iter) { |
7284 |
(*iter)->UpdateChunks(pProgress); |
(*iter)->UpdateChunks(pProgress); |
7285 |
} |
} |
7333 |
|
|
7334 |
memset(&pData[48], 0, sublen - 48); |
memset(&pData[48], 0, sublen - 48); |
7335 |
|
|
7336 |
for (Instrument* instrument = GetFirstInstrument() ; instrument ; |
size_t iIns = 0; |
7337 |
instrument = GetNextInstrument()) { |
for (Instrument* instrument = GetInstrument(iIns); instrument; |
7338 |
|
instrument = GetInstrument(++iIns)) |
7339 |
|
{ |
7340 |
int nbusedsamples = 0; |
int nbusedsamples = 0; |
7341 |
int nbusedchannels = 0; |
int nbusedchannels = 0; |
7342 |
int nbdimregions = 0; |
int nbdimregions = 0; |
7441 |
void File::UpdateFileOffsets() { |
void File::UpdateFileOffsets() { |
7442 |
DLS::File::UpdateFileOffsets(); |
DLS::File::UpdateFileOffsets(); |
7443 |
|
|
7444 |
for (Instrument* instrument = GetFirstInstrument(); instrument; |
size_t i = 0; |
7445 |
instrument = GetNextInstrument()) |
for (Instrument* instrument = GetInstrument(i); instrument; |
7446 |
|
instrument = GetInstrument(++i)) |
7447 |
{ |
{ |
7448 |
instrument->UpdateScriptFileOffsets(); |
instrument->UpdateScriptFileOffsets(); |
7449 |
} |
} |