libgig 4.4.1
|
Abstract base class which encapsulates data structures which all DLS resources are able to provide. More...
#include <DLS.h>
Public Member Functions | |
Resource * | GetParent () |
const Resource * | GetParent () const |
virtual void | UpdateChunks (progress_t *pProgress) |
Update chunks with current Resource data. | |
virtual void | DeleteChunks () |
Remove all RIFF chunks associated with this Resource object. | |
void | GenerateDLSID () |
Generates a new DLSID for the resource. | |
virtual void | CopyAssign (const Resource *orig) |
Make a deep copy of the Resource object given by orig and assign it to this object. | |
Static Public Member Functions | |
static void | GenerateDLSID (dlsid_t *pDLSID) |
Public Attributes | |
Info * | pInfo |
Points (in any case) to an Info object, providing additional, optional infos and comments. | |
dlsid_t * | pDLSID |
Points to a dlsid_t structure if the file provided a DLS ID else is NULL. | |
Protected Member Functions | |
Resource (Resource *Parent, RIFF::List *lstResource) | |
Constructor. | |
Protected Attributes | |
Resource * | pParent |
RIFF::List * | pResourceList |
Abstract base class which encapsulates data structures which all DLS resources are able to provide.
|
protected |
Constructor.
Initializes the 'Resource' object with values provided by a given INFO list chunk and a DLID chunk (the latter optional).
Parent | - pointer to parent 'Resource', NULL if this is the toplevel 'Resource' object |
lstResource | - pointer to an INFO list chunk |
Definition at line 522 of file DLS.cpp.
References RIFF::List::GetSubChunk(), pDLSID, pInfo, RIFF::Chunk::Read(), and RIFF::Chunk::SetPos().
|
virtual |
Make a deep copy of the Resource object given by orig and assign it to this object.
orig | - original Resource object to be copied from |
Definition at line 637 of file DLS.cpp.
References DLS::Info::CopyAssign(), and pInfo.
Referenced by DLS::Region::CopyAssign(), and DLS::Sample::CopyAssignCore().
|
virtual |
Remove all RIFF chunks associated with this Resource object.
At the moment Resource::DeleteChunks() does nothing. It is recommended to call this method explicitly though from deriving classes's own overridden implementation of this method to avoid potential future compatiblity issues.
See Storage::DeleteChunks() for details.
Implements DLS::Storage.
Reimplemented in DLS::Sample, DLS::Region, and DLS::Instrument.
Definition at line 555 of file DLS.cpp.
Referenced by DLS::Sample::DeleteChunks(), DLS::Region::DeleteChunks(), and DLS::Instrument::DeleteChunks().
void Resource::GenerateDLSID | ( | ) |
Generates a new DLSID for the resource.
Definition at line 587 of file DLS.cpp.
References GenerateDLSID(), and pDLSID.
Referenced by gig::File::AddInstrument(), GenerateDLSID(), gig::Script::GenerateUuid(), and DLS::File::UpdateChunks().
|
virtual |
Update chunks with current Resource data.
Apply Resource data persistently below the previously given resource list chunk. This will currently only include the INFO data. The DLSID will not be applied at the moment (yet).
You have to call File::Save() to make changes persistent.
pProgress | - callback function for progress notification |
Implements DLS::Storage.
Reimplemented in DLS::Sample, DLS::Region, DLS::Instrument, DLS::File, gig::Sample, gig::Region, gig::Instrument, and gig::File.
Definition at line 568 of file DLS.cpp.
References RIFF::List::AddSubChunk(), RIFF::List::GetSubChunk(), RIFF::Chunk::LoadChunkData(), pDLSID, pInfo, and DLS::Info::UpdateChunks().
Referenced by DLS::Sample::UpdateChunks(), DLS::Instrument::UpdateChunks(), and DLS::File::UpdateChunks().
dlsid_t* DLS::Resource::pDLSID |
Points to a dlsid_t structure if the file provided a DLS ID else is NULL.
Definition at line 407 of file DLS.h.
Referenced by GenerateDLSID(), Resource(), and UpdateChunks().
Info* DLS::Resource::pInfo |
Points (in any case) to an Info object, providing additional, optional infos and comments.
Definition at line 406 of file DLS.h.
Referenced by gig::File::AddInstrument(), CopyAssign(), Resource(), gig::Sample::Sample(), and UpdateChunks().
|
protected |