/[svn]/linuxsampler/trunk/src/engines/gig/InstrumentResourceManager.h
ViewVC logotype

Diff of /linuxsampler/trunk/src/engines/gig/InstrumentResourceManager.h

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

revision 946 by schoenebeck, Tue Jun 27 22:57:37 2006 UTC revision 947 by schoenebeck, Mon Nov 27 21:34:55 2006 UTC
# Line 32  Line 32 
32  #include "../../common/Exception.h"  #include "../../common/Exception.h"
33  #include "../../common/ResourceManager.h"  #include "../../common/ResourceManager.h"
34  #include "../../drivers/audio/AudioOutputDevice.h"  #include "../../drivers/audio/AudioOutputDevice.h"
35    #include "../InstrumentManager.h"
36    
37  //namespace libgig = gig;  //namespace libgig = gig;
38    
# Line 49  namespace LinuxSampler { namespace gig { Line 50  namespace LinuxSampler { namespace gig {
50      // just symbol prototyping      // just symbol prototyping
51      class EngineChannel;      class EngineChannel;
52    
53      /**      /** @brief Gig instrument manager
      * Explicitly identifies a Gigasampler instrument.  
      */  
     struct instrument_id_t {  
         String FileName;    ///< name of the file which contains the instrument  
         uint   iInstrument; ///< index of the instrument in the instrument file  
   
         // TODO: we should extend operator<() so it will be able to detect that file x and file y are actually the same files, e.g. because one of them is a symlink / share the same inode  
         bool operator<(const instrument_id_t& o) const {  
             return (iInstrument < o.iInstrument || (iInstrument == o.iInstrument && FileName < o.FileName));  
         }  
     };  
   
     /** Gig instrument manager  
54       *       *
55       * Manager to share gig instruments between multiple Gigasampler       * Manager to share gig instruments between multiple Gigasampler
56       * engine channels. The engine channels Borrow() instruments when they       * engine channels. The engine channels Borrow() instruments when they
# Line 70  namespace LinuxSampler { namespace gig { Line 58  namespace LinuxSampler { namespace gig {
58       * InstrumentResourceManager loads the corresponding gig file and gig       * InstrumentResourceManager loads the corresponding gig file and gig
59       * instrument if needed, if it's already in use by another engine       * instrument if needed, if it's already in use by another engine
60       * channel, then it just returns the same resource, if an gig       * channel, then it just returns the same resource, if an gig
61       * instrument / file is not in use by any engine channel anymore, then       * instrument / file is not needed anymore, then it will be freed from
62       * it will be freed from memory.       * memory.
63       */       */
64      class InstrumentResourceManager : public ResourceManager<instrument_id_t, ::gig::Instrument> {      class InstrumentResourceManager : public InstrumentManager, public ResourceManager<InstrumentManager::instrument_id_t, ::gig::Instrument> {
65          public:          public:
66              virtual ~InstrumentResourceManager() {}              virtual ~InstrumentResourceManager() {}
67              static void OnInstrumentLoadingProgress(::gig::progress_t* pProgress);              static void OnInstrumentLoadingProgress(::gig::progress_t* pProgress);
68    
69                // implementation of derived abstract methods from 'InstrumentManager'
70                virtual std::vector<instrument_id_t> Instruments();
71                virtual InstrumentManager::mode_t GetMode(const instrument_id_t& ID);
72                virtual void SetMode(const instrument_id_t& ID, InstrumentManager::mode_t Mode);
73                virtual float GetVolume(const instrument_id_t& ID);
74                virtual void SetVolume(const instrument_id_t& ID, float Volume);
75                virtual String GetInstrumentName(instrument_id_t ID);
76          protected:          protected:
77              virtual ::gig::Instrument* Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg);              virtual ::gig::Instrument* Create(instrument_id_t Key, InstrumentConsumer* pConsumer, void*& pArg);
78              virtual void               Destroy(::gig::Instrument* pResource, void* pArg);              virtual void               Destroy(::gig::Instrument* pResource, void* pArg);
79              virtual void               OnBorrow(::gig::Instrument* pResource, InstrumentConsumer* pConsumer, void*& pArg);              virtual void               OnBorrow(::gig::Instrument* pResource, InstrumentConsumer* pConsumer, void*& pArg);
80          private:          private:
             struct instr_entry_t {  
                 ::gig::File* pGig;  
                 uint         iInstrument;  
                 uint         MaxSamplesPerCycle; ///< if some engine requests an already allocated instrument with a higher value, we have to reallocate the instrument  
             };  
   
81              typedef ResourceConsumer< ::gig::File> GigConsumer;              typedef ResourceConsumer< ::gig::File> GigConsumer;
82    
83              class GigResourceManager : public ResourceManager<String, ::gig::File> {              class GigResourceManager : public ResourceManager<String, ::gig::File> {

Legend:
Removed from v.946  
changed lines
  Added in v.947

  ViewVC Help
Powered by ViewVC