/[svn]/libgig/trunk/src/DLS.h
ViewVC logotype

Diff of /libgig/trunk/src/DLS.h

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2329 by schoenebeck, Mon Mar 12 14:59:10 2012 UTC revision 3940 by schoenebeck, Fri Jun 18 13:47:46 2021 UTC
# Line 2  Line 2 
2   *                                                                         *   *                                                                         *
3   *   libgig - C++ cross-platform Gigasampler format file access library    *   *   libgig - C++ cross-platform Gigasampler format file access library    *
4   *                                                                         *   *                                                                         *
5   *   Copyright (C) 2003-2010 by Christian Schoenebeck                      *   *   Copyright (C) 2003-2021 by Christian Schoenebeck                      *
6   *                              <cuse@users.sourceforge.net>               *   *                              <cuse@users.sourceforge.net>               *
7   *                                                                         *   *                                                                         *
8   *   This library is free software; you can redistribute it and/or modify  *   *   This library is free software; you can redistribute it and/or modify  *
# Line 60  Line 60 
60  # define CHUNK_ID_COLH  0x636F6C68  # define CHUNK_ID_COLH  0x636F6C68
61  # define CHUNK_ID_ARTL  0x6172746C  # define CHUNK_ID_ARTL  0x6172746C
62  # define CHUNK_ID_ART2  0x61727432  # define CHUNK_ID_ART2  0x61727432
63    # define CHUNK_ID_XFIL  0x7866696C
64    # define CHUNK_ID_DOXF  0x646F7866
65  #else  // little endian  #else  // little endian
66  # define RIFF_TYPE_DLS  0x20534C44  # define RIFF_TYPE_DLS  0x20534C44
67  # define LIST_TYPE_WVPL 0x6C707677  # define LIST_TYPE_WVPL 0x6C707677
# Line 94  Line 96 
96  # define CHUNK_ID_COLH  0x686C6F63  # define CHUNK_ID_COLH  0x686C6F63
97  # define CHUNK_ID_ARTL  0x6C747261  # define CHUNK_ID_ARTL  0x6C747261
98  # define CHUNK_ID_ART2  0x32747261  # define CHUNK_ID_ART2  0x32747261
99    # define CHUNK_ID_XFIL  0x6C696678
100    # define CHUNK_ID_DOXF  0x66786F64
101  #endif // WORDS_BIGENDIAN  #endif // WORDS_BIGENDIAN
102    
103  #define DLS_WAVE_FORMAT_PCM                     0x0001  #define DLS_WAVE_FORMAT_PCM                     0x0001
# Line 104  Line 108 
108  namespace DLS {  namespace DLS {
109    
110      typedef std::string String;      typedef std::string String;
111        typedef RIFF::progress_t progress_t;
112        typedef RIFF::file_offset_t file_offset_t;
113    
114      /** Quadtuple version number ("major.minor.release.build"). */      /** Quadtuple version number ("major.minor.release.build"). */
115      struct version_t {      struct version_t {
# Line 122  namespace DLS { Line 128  namespace DLS {
128      };      };
129    
130      /** Connection Sources */      /** Connection Sources */
131      typedef enum {      enum conn_src_t {
132          // Modulator Sources          // Modulator Sources
133          conn_src_none            = 0x0000,          conn_src_none            = 0x0000,
134          conn_src_lfo             = 0x0001,          conn_src_lfo             = 0x0001,
# Line 145  namespace DLS { Line 151  namespace DLS {
151          conn_src_rpn0            = 0x0100,          conn_src_rpn0            = 0x0100,
152          conn_src_rpn1            = 0x0101,          conn_src_rpn1            = 0x0101,
153          conn_src_rpn2            = 0x0102          conn_src_rpn2            = 0x0102
154      } conn_src_t;      };
155    
156      /** Connection Destinations */      /** Connection Destinations */
157      typedef enum {      enum conn_dst_t {
158          // Generic Destinations          // Generic Destinations
159          conn_dst_none             = 0x0000,          conn_dst_none             = 0x0000,
160          conn_dst_gain             = 0x0001,          conn_dst_gain             = 0x0001,
# Line 190  namespace DLS { Line 196  namespace DLS {
196          // Filter Destinations          // Filter Destinations
197          conn_dst_filter_cutoff    = 0x0500,          conn_dst_filter_cutoff    = 0x0500,
198          conn_dst_filter_q         = 0x0501          conn_dst_filter_q         = 0x0501
199      } conn_dst_t;      };
200    
201      /** Connection Transforms */      /** Connection Transforms */
202      typedef enum {      enum conn_trn_t {
203          conn_trn_none    = 0x0000,          conn_trn_none    = 0x0000,
204          conn_trn_concave = 0x0001,          conn_trn_concave = 0x0001,
205          conn_trn_convex  = 0x0002,          conn_trn_convex  = 0x0002,
206          conn_trn_switch  = 0x0003          conn_trn_switch  = 0x0003
207      } conn_trn_t;      };
208    
209      /** Lower and upper limit of a range. */      /** Lower and upper limit of a range. */
210      struct range_t {      struct range_t {
211          uint16_t low;  ///< Low value of range.          uint16_t low;  ///< Low value of range.
212          uint16_t high; ///< High value of range.          uint16_t high; ///< High value of range.
213    
214            inline bool operator< (const range_t& other) const {
215                if (low < other.low) return true;
216                if (low > other.low) return false;
217                return high < other.high;
218            }
219    
220            inline bool operator== (const range_t& other) const {
221                return low == other.low && high == other.high;
222            }
223    
224            inline bool overlaps(uint16_t scalar) const {
225                return low <= scalar && scalar <= high;
226            }
227    
228            inline bool overlaps(const range_t& other) const {
229                return overlaps(other.low) || overlaps(other.high) ||
230                       other.overlaps(low) || other.overlaps(high);
231            }
232      };      };
233    
234      /** Defines Sample Loop Points. */      /** Defines Sample Loop Points. */
# Line 249  namespace DLS { Line 274  namespace DLS {
274              friend class Articulation;              friend class Articulation;
275      };      };
276    
277        /** @brief Abstract base class for all classes using RIFF::Chunks for persistency.
278         *
279         * This abstract base class defines the general interface for all classes
280         * which are using RIFF::Chunks to actually load and store their data
281         * persistently from/to disk.
282         */
283        class Storage {
284        public:
285            /** @brief Apply object's changes to the respective RIF::Chunks.
286             *
287             * This abstract interface method is intended to be implemented by the
288             * deriving classes by updating the respective RIFF chunks associated
289             * with the object such that those RIFF chunks reflect the object's
290             * current data (i.e. object's current member variables). So the purpose
291             * of this method is to prepare for saving the object's current state
292             * persistently to the actual RIFF file.
293             *
294             * After returning from this method the changes are just scheduled to be
295             * saved to the RIFF file, it is required to call File::Save()
296             * subsequently to make the changes actually persistent on file level.
297             *
298             * Usually there is no need to call this method directly from an
299             * application. This method is called automatically by libgig if one of
300             * the respective API methods is called to save the file persistently
301             * to disk (i.e. DLS::File::Save() or gig::File::Save()).
302             *
303             * @param pProgress - callback function for progress notification
304             */
305            virtual void UpdateChunks(progress_t* pProgress) = 0;
306    
307            /** @brief Remove all RIFF chunks associated with this object.
308             *
309             * This abstract interface method is intended to be implemented by the
310             * deriving classes by removing every RIFF::Chunk the deriving overall
311             * object is using to store the object in the final RIFF::File. In other
312             * words: the intention is to remove the deriving class(es)'s object
313             * persistently from the currently open file.
314             *
315             * Note that the RIFF::Chunks deletions is just scheduled after
316             * returning from this method. You have to call File::Save() to make
317             * these changes persistent on file level.
318             *
319             * Usually there is no need to call this method directly from an
320             * application. This method is called automatically by libgig if one of
321             * the respective API methods is called to remove the respective object
322             * persistently (i.e. File::DeleteInstrument() or File::DeleteSample()).
323             */
324            virtual void DeleteChunks() = 0;
325        };
326    
327      /** Provides access to the defined connections used for the synthesis model. */      /** Provides access to the defined connections used for the synthesis model. */
328      class Articulation {      class Articulation : public Storage {
329          public:          public:
330              Connection*  pConnections; ///< Points to the beginning of a <i>Connection</i> array.              Connection*  pConnections; ///< Points to the beginning of a <i>Connection</i> array.
331              uint32_t     Connections;  ///< Reflects the number of Connections.              uint32_t     Connections;  ///< Reflects the number of Connections.
332    
333              Articulation(RIFF::Chunk* artl);              Articulation(RIFF::Chunk* artl);
334              virtual ~Articulation();              virtual ~Articulation();
335              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress) OVERRIDE;
336                virtual void DeleteChunks() OVERRIDE;
337          protected:          protected:
338              RIFF::Chunk* pArticulationCk;              RIFF::Chunk* pArticulationCk;
339              uint32_t     HeaderSize;              uint32_t     HeaderSize;
340      };      };
341    
342      /** Abstract base class for classes that provide articulation information (thus for <i>Instrument</i> and <i>Region</i> class). */      /** Abstract base class for classes that provide articulation information (thus for <i>Instrument</i> and <i>Region</i> class). */
343      class Articulator {      class Articulator : public Storage {
344          public:          public:
345              Articulator(RIFF::List* ParentList);              Articulator(RIFF::List* ParentList);
346              Articulation* GetFirstArticulation();              Articulation* GetArticulation(size_t pos);
347              Articulation* GetNextArticulation();              Articulation* GetFirstArticulation() LIBGIG_DEPRECATED_API("Use GetArticulation() instead.");
348              virtual void  UpdateChunks();              Articulation* GetNextArticulation() LIBGIG_DEPRECATED_API("Use GetArticulation() instead.");
349                virtual void  UpdateChunks(progress_t* pProgress) OVERRIDE;
350                virtual void  DeleteChunks() OVERRIDE;
351                virtual void  CopyAssign(const Articulator* orig);
352          protected:          protected:
353              typedef std::list<Articulation*> ArticulationList;              typedef std::vector<Articulation*> ArticulationList;
354              RIFF::List*                 pParentList;              RIFF::List*                 pParentList;
355              ArticulationList*           pArticulations;              ArticulationList*           pArticulations;
356              ArticulationList::iterator  ArticulationsIterator;              ArticulationList::iterator  ArticulationsIterator;
# Line 281  namespace DLS { Line 360  namespace DLS {
360      };      };
361    
362      /** Optional information for DLS files, instruments, samples, etc. */      /** Optional information for DLS files, instruments, samples, etc. */
363      class Info {      class Info : public Storage {
364          public:          public:
365              String Name;             ///< <INAM-ck>. Stores the title of the subject of the file, such as, Seattle From Above.              String Name;             ///< <INAM-ck>. Stores the title of the subject of the file, such as, Seattle From Above.
366              String ArchivalLocation; ///< <IARL-ck>. Indicates where the subject of the file is stored.              String ArchivalLocation; ///< <IARL-ck>. Indicates where the subject of the file is stored.
# Line 310  namespace DLS { Line 389  namespace DLS {
389              Info(RIFF::List* list);              Info(RIFF::List* list);
390              void SetFixedStringLengths(const string_length_t* lengths);              void SetFixedStringLengths(const string_length_t* lengths);
391              virtual ~Info();              virtual ~Info();
392              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress) OVERRIDE;
393                virtual void DeleteChunks() OVERRIDE;
394                virtual void CopyAssign(const Info* orig);
395          private:          private:
396              RIFF::List*            pResourceListChunk;              RIFF::List*            pResourceListChunk;
397              const string_length_t* pFixedStringLengths; ///< List of IDs and string lengths for strings that should be stored in a fixed length format. This is used for gig files, not for ordinary DLS files.              const string_length_t* pFixedStringLengths; ///< List of IDs and string lengths for strings that should be stored in a fixed length format. This is used for gig files, not for ordinary DLS files.
# Line 320  namespace DLS { Line 401  namespace DLS {
401      };      };
402    
403      /** Abstract base class which encapsulates data structures which all DLS resources are able to provide. */      /** Abstract base class which encapsulates data structures which all DLS resources are able to provide. */
404      class Resource {      class Resource : public Storage {
405          public:          public:
406              Info*    pInfo;  ///< Points (in any case) to an <i>Info</i> object, providing additional, optional infos and comments.              Info*    pInfo;  ///< Points (in any case) to an <i>Info</i> object, providing additional, optional infos and comments.
407              dlsid_t* pDLSID; ///< Points to a <i>dlsid_t</i> structure if the file provided a DLS ID else is <i>NULL</i>.              dlsid_t* pDLSID; ///< Points to a <i>dlsid_t</i> structure if the file provided a DLS ID else is <i>NULL</i>.
408    
409              Resource* GetParent() { return pParent; }              Resource* GetParent() { return pParent; }
410              virtual void UpdateChunks();              const Resource* GetParent() const { return pParent; }
411                virtual void UpdateChunks(progress_t* pProgress) OVERRIDE;
412                virtual void DeleteChunks() OVERRIDE;
413              void GenerateDLSID();              void GenerateDLSID();
414                static void GenerateDLSID(dlsid_t* pDLSID);
415                virtual void CopyAssign(const Resource* orig);
416          protected:          protected:
417              Resource* pParent;              Resource* pParent;
418              RIFF::List* pResourceList;              RIFF::List* pResourceList;
# Line 337  namespace DLS { Line 422  namespace DLS {
422      };      };
423    
424      /** Abstract base class which provides mandatory informations about sample players in general. */      /** Abstract base class which provides mandatory informations about sample players in general. */
425      class Sampler {      class Sampler : public Storage {
426          public:          public:
427              uint8_t        UnityNote;              uint8_t        UnityNote;
428              int16_t        FineTune;              int16_t        FineTune;
# Line 350  namespace DLS { Line 435  namespace DLS {
435              void AddSampleLoop(sample_loop_t* pLoopDef);              void AddSampleLoop(sample_loop_t* pLoopDef);
436              void DeleteSampleLoop(sample_loop_t* pLoopDef);              void DeleteSampleLoop(sample_loop_t* pLoopDef);
437              virtual void SetGain(int32_t gain);              virtual void SetGain(int32_t gain);
438              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress) OVERRIDE;
439                virtual void DeleteChunks() OVERRIDE;
440                virtual void CopyAssign(const Sampler* orig);
441          protected:          protected:
442              RIFF::List*    pParentList;              RIFF::List*    pParentList;
443              uint32_t       uiHeaderSize;              uint32_t       uiHeaderSize;
# Line 375  namespace DLS { Line 462  namespace DLS {
462              uint32_t      AverageBytesPerSecond; ///< The average number of bytes per second at which the waveform data should be transferred (Playback software can estimate the buffer size using this value).              uint32_t      AverageBytesPerSecond; ///< The average number of bytes per second at which the waveform data should be transferred (Playback software can estimate the buffer size using this value).
463              uint16_t      BlockAlign;            ///< The block alignment (in bytes) of the waveform data. Playback software needs to process a multiple of <i>BlockAlign</i> bytes of data at a time, so the value of <i>BlockAlign</i> can be used for buffer alignment.              uint16_t      BlockAlign;            ///< The block alignment (in bytes) of the waveform data. Playback software needs to process a multiple of <i>BlockAlign</i> bytes of data at a time, so the value of <i>BlockAlign</i> can be used for buffer alignment.
464              uint16_t      BitDepth;              ///< Size of each sample per channel (only if known sample data format is used, 0 otherwise).              uint16_t      BitDepth;              ///< Size of each sample per channel (only if known sample data format is used, 0 otherwise).
465              unsigned long SamplesTotal;          ///< Reflects total number of sample points (only if known sample data format is used, 0 otherwise), do not bother to change this value, it will not be saved.              file_offset_t SamplesTotal;          ///< Reflects total number of sample points (only if known sample data format is used, 0 otherwise), do not bother to change this value, it will not be saved.
466              uint          FrameSize;             ///< Reflects the size (in bytes) of one single sample point (only if known sample data format is used, 0 otherwise). <b>Caution:</b> with the current version of libgig you have to upate this field by yourself whenever you change one of the following fields: Channels, BitDepth ! Ignoring this might lead to undesired behavior when i.e. calling Resize(), SetPos(), Write() or Read().              uint          FrameSize;             ///< Reflects the size (in bytes) of one single sample point (only if known sample data format is used, 0 otherwise). <b>Caution:</b> with the current version of libgig you have to upate this field by yourself whenever you change one of the following fields: Channels, BitDepth ! Ignoring this might lead to undesired behavior when i.e. calling Resize(), SetPos(), Write() or Read().
467    
468              void*         LoadSampleData();              void*         LoadSampleData();
469              void          ReleaseSampleData();              void          ReleaseSampleData();
470              unsigned long GetSize();              file_offset_t GetSize() const;
471              void          Resize(int iNewSize);              void          Resize(file_offset_t NewSize);
472              unsigned long SetPos(unsigned long SampleCount, RIFF::stream_whence_t Whence = RIFF::stream_start);              file_offset_t SetPos(file_offset_t SampleCount, RIFF::stream_whence_t Whence = RIFF::stream_start);
473              unsigned long Read(void* pBuffer, unsigned long SampleCount);              file_offset_t Read(void* pBuffer, file_offset_t SampleCount);
474              unsigned long Write(void* pBuffer, unsigned long SampleCount);              file_offset_t Write(void* pBuffer, file_offset_t SampleCount);
475              virtual void  UpdateChunks();              virtual void  UpdateChunks(progress_t* pProgress) OVERRIDE;
476                virtual void  DeleteChunks() OVERRIDE;
477                virtual void  CopyAssign(const Sample* orig);
478    
479          protected:          protected:
480              RIFF::List*   pWaveList;              RIFF::List*   pWaveList;
481              RIFF::Chunk*  pCkData;              RIFF::Chunk*  pCkData;
482              RIFF::Chunk*  pCkFormat;              RIFF::Chunk*  pCkFormat;
483              unsigned long ulWavePoolOffset;  // needed for comparison with the wave pool link table, thus the link to instruments              file_offset_t ullWavePoolOffset;  // needed for comparison with the wave pool link table, thus the link to instruments
484    
485              Sample(File* pFile, RIFF::List* waveList, unsigned long WavePoolOffset);              Sample(File* pFile, RIFF::List* waveList, file_offset_t WavePoolOffset);
486              virtual ~Sample();              virtual ~Sample();
487                void CopyAssignCore(const Sample* orig);
488              friend class File;              friend class File;
489              friend class Region; // Region has to compare the wave pool offset to get its sample              friend class Region; // Region has to compare the wave pool offset to get its sample
490      };      };
# Line 414  namespace DLS { Line 505  namespace DLS {
505              Sample*     GetSample();              Sample*     GetSample();
506              void        SetSample(Sample* pSample);              void        SetSample(Sample* pSample);
507              virtual void SetKeyRange(uint16_t Low, uint16_t High);              virtual void SetKeyRange(uint16_t Low, uint16_t High);
508              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress) OVERRIDE;
509                virtual void DeleteChunks() OVERRIDE;
510                virtual void CopyAssign(const Region* orig);
511          protected:          protected:
512              RIFF::List* pCkRegion;              RIFF::List* pCkRegion;
513              uint32_t    WavePoolTableIndex; // index in the wave pool table to the sample wave this region is linked to              uint32_t    WavePoolTableIndex; // index in the wave pool table to the sample wave this region is linked to
# Line 437  namespace DLS { Line 530  namespace DLS {
530              uint32_t MIDIProgram;    ///< Specifies the MIDI Program Change Number this Instrument should be assigned to.              uint32_t MIDIProgram;    ///< Specifies the MIDI Program Change Number this Instrument should be assigned to.
531              uint32_t Regions;        ///< Reflects the number of <i>Region</i> defintions this Instrument has.              uint32_t Regions;        ///< Reflects the number of <i>Region</i> defintions this Instrument has.
532    
533              Region*  GetFirstRegion();              Region*  GetRegionAt(size_t pos);
534              Region*  GetNextRegion();              Region*  GetFirstRegion() LIBGIG_DEPRECATED_API("Use GetRegionAt() instead.");
535                Region*  GetNextRegion() LIBGIG_DEPRECATED_API("Use GetRegionAt() instead.");
536              Region*  AddRegion();              Region*  AddRegion();
537              void     DeleteRegion(Region* pRegion);              void     DeleteRegion(Region* pRegion);
538              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress) OVERRIDE;
539                virtual void DeleteChunks() OVERRIDE;
540                virtual void CopyAssign(const Instrument* orig);
541          protected:          protected:
542              typedef std::list<Region*> RegionList;              typedef std::vector<Region*> RegionList;
543              struct midi_locale_t {              struct midi_locale_t {
544                  uint32_t bank;                  uint32_t bank;
545                  uint32_t instrument;                  uint32_t instrument;
# Line 454  namespace DLS { Line 550  namespace DLS {
550              RegionList::iterator RegionsIterator;              RegionList::iterator RegionsIterator;
551    
552              Instrument(File* pFile, RIFF::List* insList);              Instrument(File* pFile, RIFF::List* insList);
553                void CopyAssignCore(const Instrument* orig);
554              virtual void LoadRegions();              virtual void LoadRegions();
555              virtual ~Instrument();              virtual ~Instrument();
556              friend class File;              friend class File;
# Line 471  namespace DLS { Line 568  namespace DLS {
568              File();              File();
569              File(RIFF::File* pRIFF);              File(RIFF::File* pRIFF);
570              String      GetFileName();              String      GetFileName();
571              Sample*     GetFirstSample();     ///< Returns a pointer to the first <i>Sample</i> object of the file, <i>NULL</i> otherwise.              void        SetFileName(const String& name);
572              Sample*     GetNextSample();      ///< Returns a pointer to the next <i>Sample</i> object of the file, <i>NULL</i> otherwise.              Sample*     GetSample(size_t index);
573                Sample*     GetFirstSample() LIBGIG_DEPRECATED_API("Use GetSample() instead.");
574                Sample*     GetNextSample() LIBGIG_DEPRECATED_API("Use GetSample() instead.");
575              Sample*     AddSample();              Sample*     AddSample();
576              void        DeleteSample(Sample* pSample);              void        DeleteSample(Sample* pSample);
577              Instrument* GetFirstInstrument(); ///< Returns a pointer to the first <i>Instrument</i> object of the file, <i>NULL</i> otherwise.              Instrument* GetFirstInstrument(); ///< Returns a pointer to the first <i>Instrument</i> object of the file, <i>NULL</i> otherwise.
578              Instrument* GetNextInstrument();  ///< Returns a pointer to the next <i>Instrument</i> object of the file, <i>NULL</i> otherwise.              Instrument* GetNextInstrument();  ///< Returns a pointer to the next <i>Instrument</i> object of the file, <i>NULL</i> otherwise.
579              Instrument* AddInstrument();              Instrument* AddInstrument();
580              void        DeleteInstrument(Instrument* pInstrument);              void        DeleteInstrument(Instrument* pInstrument);
581                RIFF::File* GetRiffFile();
582              RIFF::File* GetExtensionFile(int index);              RIFF::File* GetExtensionFile(int index);
583              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress) OVERRIDE;
584              virtual void Save(const String& Path);              virtual void Save(const String& Path, progress_t* pProgress = NULL);
585              virtual void Save();              virtual void Save(progress_t* pProgress = NULL);
586              virtual ~File();              virtual ~File();
587          protected:          protected:
588              typedef std::list<Sample*>     SampleList;              typedef std::vector<Sample*>     SampleList;
589              typedef std::list<Instrument*> InstrumentList;              typedef std::list<Instrument*> InstrumentList;
590    
591              RIFF::File*              pRIFF;              RIFF::File*              pRIFF;
592              std::list<RIFF::File*>   ExtensionFiles;              std::list<RIFF::File*>   ExtensionFiles; //FIXME: These should automatically be freed, since implicitly allocated.
593              SampleList*              pSamples;              SampleList*              pSamples;
594              SampleList::iterator     SamplesIterator;              SampleList::iterator     SamplesIterator;
595              InstrumentList*          pInstruments;              InstrumentList*          pInstruments;
# Line 499  namespace DLS { Line 599  namespace DLS {
599              uint32_t*                pWavePoolTable;              uint32_t*                pWavePoolTable;
600              uint32_t*                pWavePoolTableHi;              uint32_t*                pWavePoolTableHi;
601              bool                     b64BitWavePoolOffsets;              bool                     b64BitWavePoolOffsets;
602                bool                     bOwningRiff; ///< If @c true then @c pRIFF was implicitly allocated by this class and hence pRIFF will automatically be freed by the @c DLS::File destructor in that case.
603    
604              virtual void LoadSamples();              virtual void LoadSamples();
605              virtual void LoadInstruments();              virtual void LoadInstruments();
606                virtual void UpdateFileOffsets();
607              void __ensureMandatoryChunksExist();              void __ensureMandatoryChunksExist();
608              friend class Region; // Region has to look in the wave pool table to get its sample              friend class Region; // Region has to look in the wave pool table to get its sample
609          private:          private:
# Line 518  namespace DLS { Line 620  namespace DLS {
620       */       */
621      class Exception : public RIFF::Exception {      class Exception : public RIFF::Exception {
622          public:          public:
623              Exception(String Message);              Exception(String format, ...);
624                Exception(String format, va_list arg);
625              void PrintMessage();              void PrintMessage();
626            protected:
627                Exception();
628      };      };
629    
630      String libraryName();      String libraryName();

Legend:
Removed from v.2329  
changed lines
  Added in v.3940

  ViewVC Help
Powered by ViewVC