love-canvas_getPixel / src / modules / filesystem / File.h

/**
 * Copyright (c) 2006-2012 LOVE Development Team
 *
 * This software is provided 'as-is', without any express or implied
 * warranty.  In no event will the authors be held liable for any damages
 * arising from the use of this software.
 *
 * Permission is granted to anyone to use this software for any purpose,
 * including commercial applications, and to alter it and redistribute it
 * freely, subject to the following restrictions:
 *
 * 1. The origin of this software must not be misrepresented; you must not
 *    claim that you wrote the original software. If you use this software
 *    in a product, an acknowledgment in the product documentation would be
 *    appreciated but is not required.
 * 2. Altered source versions must be plainly marked as such, and must not be
 *    misrepresented as being the original software.
 * 3. This notice may not be removed or altered from any source distribution.
 **/

#ifndef LOVE_FILESYSTEM_FILE_H
#define LOVE_FILESYSTEM_FILE_H

// STD
#include <string>

// LOVE
#include "common/Data.h"
#include "common/Object.h"
#include "common/StringMap.h"
#include "common/int.h"
#include "FileData.h"

namespace love
{
namespace filesystem
{

/**
 * A File interface, providing generic means of reading from and
 * writing to files.
 **/
class File : public Object
{
public:

	/**
	 * File open mode.
	 **/
	enum Mode
	{
		CLOSED,
		READ,
		WRITE,
		APPEND,
		MODE_MAX_ENUM
	};

	/**
	 * Used to indicate ALL data in a file.
	 **/
	static const int64 ALL = -1;

	/**
	 * Destructor.
	 **/
	virtual ~File();

	/**
	 * Opens the file in a certain mode.
	 *
	 * @param mode READ, WRITE, APPEND.
	 * @return True if successful, false otherwise.
	 **/
	virtual bool open(Mode mode) = 0;

	/**
	 * Closes the file.
	 *
	 * @return True if successful, false otherwise.
	 **/
	virtual bool close() = 0;

	/**
	 * Gets the size of the file.
	 *
	 * @return The size of the file.
	 **/
	virtual int64 getSize() = 0;

	/**
	 * Reads data from the file and allocates a Data object.
	 *
	 * @param size The number of bytes to attempt reading, or -1 for EOF.
	 * @return A newly allocated Data object.
	 **/
	virtual FileData *read(int64 size = ALL) = 0;

	/**
	 * Reads data into the destination buffer.
	 *
	 * @param dst The destination buffer.
	 * @param size The number of bytes to attempt reading.
	 * @return The number of bytes actually read.
	 **/
	virtual int64 read(void *dst, int64 size) = 0;

	/**
	 * Writes data into the File.
	 *
	 * @param data The source buffer.
	 * @param size The size of the buffer.
	 * @return True of success, false otherwise.
	 **/
	virtual bool write(const void *data, int64 size) = 0;

	/**
	 * Writes a Data object into the File.
	 *
	 * @param data The data object to write into the file.
	 * @param size The number of bytes to attempt writing, or -1 for everything.
	 * @return True of success, false otherwise.
	 **/
	virtual bool write(const Data *data, int64 size = ALL) = 0;

	/**
	 * Checks whether we are currently at end-of-file.
	 *
	 * @return True if EOF, false otherwise.
	 **/
	virtual bool eof() = 0;

	/**
	 * Gets the current position in the File.
	 *
	 * @return The current byte position in the File.
	 **/
	virtual int64 tell() = 0;

	/**
	 * Seeks to a certain position in the File.
	 *
	 * @param pos The byte position in the file.
	 * @return True on success, false otherwise.
	 **/
	virtual bool seek(uint64 pos) = 0;

	/**
	 * Gets the current mode of the File.
	 * @return The current mode of the File; CLOSED, READ, WRITE or APPEND.
	 **/
	virtual Mode getMode() = 0;

	/**
	 * Gets the filename for this File, or empty string if none.
	 * @return The filename for this File.
	 **/
	virtual std::string getFilename() const = 0;

	/**
	 * Gets the file extension for this File, or empty string if none.
	 * @return The file extension for this File (without the dot).
	 **/
	virtual std::string getExtension() const = 0;

	static bool getConstant(const char *in, Mode &out);
	static bool getConstant(Mode in, const char  *&out);

private:

	static StringMap<Mode, MODE_MAX_ENUM>::Entry modeEntries[];
	static StringMap<Mode, MODE_MAX_ENUM> modes;

}; // File

} // filesystem
} // love

#endif // LOVE_FILESYSTEM_FILE_H
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.