mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 19:56:37 +00:00 
			
		
		
		
	Added more capabilities to Audiere sources
This commit is contained in:
		
							parent
							
								
									d60f0fa900
								
							
						
					
					
						commit
						d22bea5eab
					
				
					 3 changed files with 22 additions and 10 deletions
				
			
		|  | @ -33,7 +33,8 @@ class SampleSource : public Stream::Stream | ||||||
| 
 | 
 | ||||||
|   bool eof() const { return isEof; } |   bool eof() const { return isEof; } | ||||||
| 
 | 
 | ||||||
|   // Disabled functions
 |   // Disabled functions by default. You can still override them in
 | ||||||
|  |   // subclasses.
 | ||||||
|   void seek(size_t pos) const { assert(0); } |   void seek(size_t pos) const { assert(0); } | ||||||
|   size_t tell() const { assert(0); } |   size_t tell() const { assert(0); } | ||||||
|   size_t size() const { assert(0); } |   size_t size() const { assert(0); } | ||||||
|  |  | ||||||
|  | @ -28,12 +28,15 @@ void AudiereSource::getInfo(int32_t *rate, int32_t *channels, int32_t *bits) | ||||||
| { | { | ||||||
|   SampleFormat fmt; |   SampleFormat fmt; | ||||||
|   sample->getFormat(*channels, *rate, fmt); |   sample->getFormat(*channels, *rate, fmt); | ||||||
|  |   if(bits) | ||||||
|  |     { | ||||||
|       if(fmt == SF_U8) |       if(fmt == SF_U8) | ||||||
|         *bits = 8; |         *bits = 8; | ||||||
|       else if(fmt == SF_S16) |       else if(fmt == SF_S16) | ||||||
|         *bits = 16; |         *bits = 16; | ||||||
|       else assert(0); |       else assert(0); | ||||||
|     } |     } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|   Get data. Since Audiere operates with frames, not bytes, there's a |   Get data. Since Audiere operates with frames, not bytes, there's a | ||||||
|  | @ -103,7 +106,7 @@ AudiereSource::AudiereSource(const std::string &file) | ||||||
|   if(!sample) |   if(!sample) | ||||||
|     fail("Couldn't load file " + file); |     fail("Couldn't load file " + file); | ||||||
| 
 | 
 | ||||||
|   getFormat(); |   setup(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| AudiereSource::AudiereSource(Stream::Stream *input) | AudiereSource::AudiereSource(Stream::Stream *input) | ||||||
|  | @ -114,15 +117,15 @@ AudiereSource::AudiereSource(Stream::Stream *input) | ||||||
|   if(!sample) |   if(!sample) | ||||||
|     fail("Couldn't load stream"); |     fail("Couldn't load stream"); | ||||||
| 
 | 
 | ||||||
|   getFormat(); |   setup(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| AudiereSource::AudiereSource(audiere::SampleSourcePtr src) | AudiereSource::AudiereSource(audiere::SampleSourcePtr src) | ||||||
|   : sample(src) |   : sample(src) | ||||||
| { assert(sample); getFormat(); } | { assert(sample); setup(); } | ||||||
| 
 | 
 | ||||||
| // Common function called from all constructors
 | // Common function called from all constructors
 | ||||||
| AudiereSource::getFormat() | AudiereSource::setup() | ||||||
| { | { | ||||||
|   assert(sample); |   assert(sample); | ||||||
| 
 | 
 | ||||||
|  | @ -136,4 +139,8 @@ AudiereSource::getFormat() | ||||||
|   // Make sure that our pullover hack will work. Increase this size if
 |   // Make sure that our pullover hack will work. Increase this size if
 | ||||||
|   // this doesn't work in all cases.
 |   // this doesn't work in all cases.
 | ||||||
|   assert(frameSize <= PSIZE); |   assert(frameSize <= PSIZE); | ||||||
|  | 
 | ||||||
|  |   isSeekable = sample->isSeekable(); | ||||||
|  |   hasPosition = true; | ||||||
|  |   hasSize = true; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -40,6 +40,10 @@ class AudiereSource : public SampleSource | ||||||
| 
 | 
 | ||||||
|   void getInfo(int32_t *rate, int32_t *channels, int32_t *bits); |   void getInfo(int32_t *rate, int32_t *channels, int32_t *bits); | ||||||
|   size_t read(void *data, size_t length); |   size_t read(void *data, size_t length); | ||||||
|  | 
 | ||||||
|  |   void seek(size_t pos) const { sample->setPosition(pos); } | ||||||
|  |   size_t tell() const { return sample->getPosition(); } | ||||||
|  |   size_t size() const { return sample->getLength(); } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #include "loadertemplate.h" | #include "loadertemplate.h" | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue