/[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 2609 by schoenebeck, Sun Jun 8 19:00:30 2014 UTC revision 3323 by schoenebeck, Thu Jul 20 22:09:54 2017 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-2014 by Christian Schoenebeck                      *   *   Copyright (C) 2003-2017 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 104  Line 104 
104  namespace DLS {  namespace DLS {
105    
106      typedef std::string String;      typedef std::string String;
107        typedef RIFF::progress_t progress_t;
108        typedef RIFF::file_offset_t file_offset_t;
109    
110      /** Quadtuple version number ("major.minor.release.build"). */      /** Quadtuple version number ("major.minor.release.build"). */
111      struct version_t {      struct version_t {
# Line 122  namespace DLS { Line 124  namespace DLS {
124      };      };
125    
126      /** Connection Sources */      /** Connection Sources */
127      typedef enum {      enum conn_src_t {
128          // Modulator Sources          // Modulator Sources
129          conn_src_none            = 0x0000,          conn_src_none            = 0x0000,
130          conn_src_lfo             = 0x0001,          conn_src_lfo             = 0x0001,
# Line 145  namespace DLS { Line 147  namespace DLS {
147          conn_src_rpn0            = 0x0100,          conn_src_rpn0            = 0x0100,
148          conn_src_rpn1            = 0x0101,          conn_src_rpn1            = 0x0101,
149          conn_src_rpn2            = 0x0102          conn_src_rpn2            = 0x0102
150      } conn_src_t;      };
151    
152      /** Connection Destinations */      /** Connection Destinations */
153      typedef enum {      enum conn_dst_t {
154          // Generic Destinations          // Generic Destinations
155          conn_dst_none             = 0x0000,          conn_dst_none             = 0x0000,
156          conn_dst_gain             = 0x0001,          conn_dst_gain             = 0x0001,
# Line 190  namespace DLS { Line 192  namespace DLS {
192          // Filter Destinations          // Filter Destinations
193          conn_dst_filter_cutoff    = 0x0500,          conn_dst_filter_cutoff    = 0x0500,
194          conn_dst_filter_q         = 0x0501          conn_dst_filter_q         = 0x0501
195      } conn_dst_t;      };
196    
197      /** Connection Transforms */      /** Connection Transforms */
198      typedef enum {      enum conn_trn_t {
199          conn_trn_none    = 0x0000,          conn_trn_none    = 0x0000,
200          conn_trn_concave = 0x0001,          conn_trn_concave = 0x0001,
201          conn_trn_convex  = 0x0002,          conn_trn_convex  = 0x0002,
202          conn_trn_switch  = 0x0003          conn_trn_switch  = 0x0003
203      } conn_trn_t;      };
204    
205      /** Lower and upper limit of a range. */      /** Lower and upper limit of a range. */
206      struct range_t {      struct range_t {
# Line 276  namespace DLS { Line 278  namespace DLS {
278    
279              Articulation(RIFF::Chunk* artl);              Articulation(RIFF::Chunk* artl);
280              virtual ~Articulation();              virtual ~Articulation();
281              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress);
282          protected:          protected:
283              RIFF::Chunk* pArticulationCk;              RIFF::Chunk* pArticulationCk;
284              uint32_t     HeaderSize;              uint32_t     HeaderSize;
# Line 288  namespace DLS { Line 290  namespace DLS {
290              Articulator(RIFF::List* ParentList);              Articulator(RIFF::List* ParentList);
291              Articulation* GetFirstArticulation();              Articulation* GetFirstArticulation();
292              Articulation* GetNextArticulation();              Articulation* GetNextArticulation();
293              virtual void  UpdateChunks();              virtual void  UpdateChunks(progress_t* pProgress);
294              virtual void  CopyAssign(const Articulator* orig);              virtual void  CopyAssign(const Articulator* orig);
295          protected:          protected:
296              typedef std::list<Articulation*> ArticulationList;              typedef std::list<Articulation*> ArticulationList;
# Line 330  namespace DLS { Line 332  namespace DLS {
332              Info(RIFF::List* list);              Info(RIFF::List* list);
333              void SetFixedStringLengths(const string_length_t* lengths);              void SetFixedStringLengths(const string_length_t* lengths);
334              virtual ~Info();              virtual ~Info();
335              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress);
336              virtual void CopyAssign(const Info* orig);              virtual void CopyAssign(const Info* orig);
337          private:          private:
338              RIFF::List*            pResourceListChunk;              RIFF::List*            pResourceListChunk;
# Line 348  namespace DLS { Line 350  namespace DLS {
350    
351              Resource* GetParent() { return pParent; }              Resource* GetParent() { return pParent; }
352              const Resource* GetParent() const { return pParent; }              const Resource* GetParent() const { return pParent; }
353              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress);
354              void GenerateDLSID();              void GenerateDLSID();
355              virtual void CopyAssign(const Resource* orig);              virtual void CopyAssign(const Resource* orig);
356          protected:          protected:
# Line 373  namespace DLS { Line 375  namespace DLS {
375              void AddSampleLoop(sample_loop_t* pLoopDef);              void AddSampleLoop(sample_loop_t* pLoopDef);
376              void DeleteSampleLoop(sample_loop_t* pLoopDef);              void DeleteSampleLoop(sample_loop_t* pLoopDef);
377              virtual void SetGain(int32_t gain);              virtual void SetGain(int32_t gain);
378              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress);
379              virtual void CopyAssign(const Sampler* orig);              virtual void CopyAssign(const Sampler* orig);
380          protected:          protected:
381              RIFF::List*    pParentList;              RIFF::List*    pParentList;
# Line 399  namespace DLS { Line 401  namespace DLS {
401              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).
402              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.
403              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).
404              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.
405              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().
406    
407              void*         LoadSampleData();              void*         LoadSampleData();
408              void          ReleaseSampleData();              void          ReleaseSampleData();
409              unsigned long GetSize() const;              file_offset_t GetSize() const;
410              void          Resize(int iNewSize);              void          Resize(file_offset_t NewSize);
411              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);
412              unsigned long Read(void* pBuffer, unsigned long SampleCount);              file_offset_t Read(void* pBuffer, file_offset_t SampleCount);
413              unsigned long Write(void* pBuffer, unsigned long SampleCount);              file_offset_t Write(void* pBuffer, file_offset_t SampleCount);
414              virtual void  UpdateChunks();              virtual void  UpdateChunks(progress_t* pProgress);
415              virtual void  CopyAssign(const Sample* orig);              virtual void  CopyAssign(const Sample* orig);
416    
417          protected:          protected:
418              RIFF::List*   pWaveList;              RIFF::List*   pWaveList;
419              RIFF::Chunk*  pCkData;              RIFF::Chunk*  pCkData;
420              RIFF::Chunk*  pCkFormat;              RIFF::Chunk*  pCkFormat;
421              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
422    
423              Sample(File* pFile, RIFF::List* waveList, unsigned long WavePoolOffset);              Sample(File* pFile, RIFF::List* waveList, file_offset_t WavePoolOffset);
424              virtual ~Sample();              virtual ~Sample();
425              void CopyAssignCore(const Sample* orig);              void CopyAssignCore(const Sample* orig);
426              friend class File;              friend class File;
# Line 440  namespace DLS { Line 443  namespace DLS {
443              Sample*     GetSample();              Sample*     GetSample();
444              void        SetSample(Sample* pSample);              void        SetSample(Sample* pSample);
445              virtual void SetKeyRange(uint16_t Low, uint16_t High);              virtual void SetKeyRange(uint16_t Low, uint16_t High);
446              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress);
447              virtual void CopyAssign(const Region* orig);              virtual void CopyAssign(const Region* orig);
448          protected:          protected:
449              RIFF::List* pCkRegion;              RIFF::List* pCkRegion;
# Line 468  namespace DLS { Line 471  namespace DLS {
471              Region*  GetNextRegion();              Region*  GetNextRegion();
472              Region*  AddRegion();              Region*  AddRegion();
473              void     DeleteRegion(Region* pRegion);              void     DeleteRegion(Region* pRegion);
474              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress);
475              virtual void CopyAssign(const Instrument* orig);              virtual void CopyAssign(const Instrument* orig);
476          protected:          protected:
477              typedef std::list<Region*> RegionList;              typedef std::list<Region*> RegionList;
# Line 510  namespace DLS { Line 513  namespace DLS {
513              Instrument* AddInstrument();              Instrument* AddInstrument();
514              void        DeleteInstrument(Instrument* pInstrument);              void        DeleteInstrument(Instrument* pInstrument);
515              RIFF::File* GetExtensionFile(int index);              RIFF::File* GetExtensionFile(int index);
516              virtual void UpdateChunks();              virtual void UpdateChunks(progress_t* pProgress);
517              virtual void Save(const String& Path);              virtual void Save(const String& Path, progress_t* pProgress = NULL);
518              virtual void Save();              virtual void Save(progress_t* pProgress = NULL);
519              virtual ~File();              virtual ~File();
520          protected:          protected:
521              typedef std::list<Sample*>     SampleList;              typedef std::list<Sample*>     SampleList;
# Line 549  namespace DLS { Line 552  namespace DLS {
552       */       */
553      class Exception : public RIFF::Exception {      class Exception : public RIFF::Exception {
554          public:          public:
555              Exception(String Message);              Exception(String format, ...);
556                Exception(String format, va_list arg);
557              void PrintMessage();              void PrintMessage();
558            protected:
559                Exception();
560      };      };
561    
562      String libraryName();      String libraryName();

Legend:
Removed from v.2609  
changed lines
  Added in v.3323

  ViewVC Help
Powered by ViewVC