 16e598b2c0
			
		
	
	
		16e598b2c0
		
			
		
	
	
	
	
		
			
			* Initial buffered file stream implementation * Fix logical errors * Fix more logical errors * Minimally working implementation * Adapt infrared unit tests for buffered streams * Increase read buffer size from 512 to 1K * Correct naming and formatting * More code improvements * Allow passing access and open modes for buffered streams * Implement tests for buffered streams * Better file and method names * Add comments and correct formatting * Use buffered streams in Infrared * Fix compilation error
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include "stream.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| typedef struct StreamCache StreamCache;
 | |
| 
 | |
| /**
 | |
|  * Allocate stream cache.
 | |
|  * @return StreamCache* pointer to a StreamCache instance
 | |
|  */
 | |
| StreamCache* stream_cache_alloc();
 | |
| 
 | |
| /**
 | |
|  * Free stream cache.
 | |
|  * @param cache Pointer to a StreamCache instance
 | |
|  */
 | |
| void stream_cache_free(StreamCache* cache);
 | |
| 
 | |
| /**
 | |
|  * Drop the cache contents and set it to initial state.
 | |
|  * @param cache Pointer to a StreamCache instance
 | |
|  */
 | |
| void stream_cache_drop(StreamCache* cache);
 | |
| 
 | |
| /**
 | |
|  * Determine if the internal cursor is at end the end of cached data.
 | |
|  * @param cache Pointer to a StreamCache instance
 | |
|  * @return True if cursor is at end, otherwise false.
 | |
|  */
 | |
| bool stream_cache_at_end(StreamCache* cache);
 | |
| 
 | |
| /**
 | |
|  * Get the current size of cached data.
 | |
|  * @param cache Pointer to a StreamCache instance
 | |
|  * @return Size of cached data.
 | |
|  */
 | |
| size_t stream_cache_size(StreamCache* cache);
 | |
| 
 | |
| /**
 | |
|  * Get the internal cursor position.
 | |
|  * @param cache Pointer to a StreamCache instance
 | |
|  * @return Cursor position inside the cache.
 | |
|  */
 | |
| size_t stream_cache_pos(StreamCache* cache);
 | |
| 
 | |
| /**
 | |
|  * Load the cache with new data from a stream.
 | |
|  * @param cache Pointer to a StreamCache instance
 | |
|  * @param stream Pointer to a Stream instance
 | |
|  * @return Size of newly cached data.
 | |
|  */
 | |
| size_t stream_cache_fill(StreamCache* cache, Stream* stream);
 | |
| 
 | |
| /**
 | |
|  * Read cached data and advance the internal cursor.
 | |
|  * @param cache Pointer to a StreamCache instance.
 | |
|  * @param data Pointer to a data buffer. Must be initialized.
 | |
|  * @param size Maximum size in bytes to read from the cache.
 | |
|  * @return Actual size that was read.
 | |
|  */
 | |
| size_t stream_cache_read(StreamCache* cache, uint8_t* data, size_t size);
 | |
| 
 | |
| /**
 | |
|  * Move the internal cursor relatively to its current position.
 | |
|  * @param cache Pointer to a StreamCache instance.
 | |
|  * @param offset Cursor offset.
 | |
|  * @return Actual cursor offset. Equal to offset parameter on hit.
 | |
|  */
 | |
| int32_t stream_cache_seek(StreamCache* cache, int32_t offset);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 |