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); |
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(); |
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 |
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 |
|
|
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 |
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 |
|
|
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 |
} |
} |