caudio/include/IDataSource.h

47 lines
1.5 KiB
C
Raw Normal View History

2010-02-09 05:18:39 +01:00
// Copyright (c) 2008-2010 Raynaldo (Wildicv) Rivera, Joshua (Dark_Kilauea) Jones
// This file is part of the "cAudio Engine"
// For conditions of distribution and use, see copyright notice in cAudio.h
2009-06-21 05:24:30 +02:00
#ifndef IDATASOURCE_H
#define IDATASOURCE_H
#include "IRefCounted.h"
2009-06-21 05:24:30 +02:00
namespace cAudio
2009-06-21 05:24:30 +02:00
{
//! Interface for data providers in cAudio.
class IDataSource : public IRefCounted
{
public:
IDataSource() { }
virtual ~IDataSource() { }
2009-06-21 05:24:30 +02:00
//! Returns whether the source is valid.
/**
\return Returns false in case of an error, like the file couldn't be found. */
virtual bool isValid() = 0;
2009-06-21 05:24:30 +02:00
//! Returns the current location in the data stream.
virtual int getCurrentPos() = 0;
2009-06-21 05:24:30 +02:00
//! Returns the total size of the data stream.
virtual int getSize() = 0;
2009-06-21 05:24:30 +02:00
//! Reads out a section of the data stream.
/**
\param output: Pointer to a location to put the read data.
\param size: Size in bytes of the data to read.
\return Number of bytes actually read. 0 bytes may indicate end of file or stream. */
virtual int read(void* output, int size) = 0;
2009-06-21 05:24:30 +02:00
//! Seek to a position in the data stream.
/**
\param amount: Amount in bytes to seek to.
\param relative: If true the number of bytes in amount is relative to the current position in the stream.
\return True if seek was successful, false if not. */
virtual bool seek(int amount, bool relative) = 0;
};
2009-06-21 05:24:30 +02:00
};
#endif //! IDATASOURCE_H