love / src / modules / filesystem / FileData.h

 * Copyright (c) 2006-2013 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.


#include <string>
#include "common/Data.h"
#include "common/StringMap.h"
#include "common/int.h"

namespace love
namespace filesystem

class FileData : public Data

	enum Decoder
	}; // Decoder

	FileData(uint64 size, const std::string &filename);

	virtual ~FileData();

	// Implements Data.
	void *getData() const;
	//TODO: Enable this
	//uint64 getSize() const;
	int getSize() const;

	const std::string &getFilename() const;
	const std::string &getExtension() const;

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


	// The actual data.
	char *data;

	// Size of the data.
	uint64 size;

	// The filename used for error purposes.
	std::string filename;

	// The extension (without dot). Used to identify file type.
	std::string extension;

	static StringMap<Decoder, DECODE_MAX_ENUM>::Entry decoderEntries[];
	static StringMap<Decoder, DECODE_MAX_ENUM> decoders;

}; // FileData

} // filesystem
} // love