/*
 * Copyright (c) 2010-2013 Remko Tronçon
 * Licensed under the GNU General Public License v3.
 * See Documentation/Licenses/GPLv3.txt for more information.
 */

#include <Swiften/Base/ByteArray.h>

#include <boost/numeric/conversion/cast.hpp>
#include <boost/filesystem/fstream.hpp>

namespace Swift {

static const int BUFFER_SIZE = 4096;

void readByteArrayFromFile(ByteArray& data, const boost::filesystem::path& file) {
	boost::filesystem::ifstream input(file, std::ios_base::in|std::ios_base::binary);
	while (input.good()) {
		size_t oldSize = data.size();
		data.resize(oldSize + BUFFER_SIZE);
		input.read(reinterpret_cast<char*>(&data[oldSize]), BUFFER_SIZE);
		data.resize(oldSize + boost::numeric_cast<size_t>(input.gcount()));
	}
	input.close();
}

std::vector<unsigned char> createByteArray(const std::string& s) {
	return std::vector<unsigned char>(s.begin(), s.end());
}

std::vector<unsigned char> createByteArray(const char* c) {
	std::vector<unsigned char> data;
	while (*c) {
		data.push_back(static_cast<unsigned char>(*c));
		++c;
	}
	return data;
}

std::string byteArrayToString(const ByteArray& b) {
	size_t i;
	for (i = b.size(); i > 0; --i) {
		if (b[i - 1] != 0) {
			break;
		}
	}
	return i > 0 ? std::string(reinterpret_cast<const char*>(vecptr(b)), i) : "";
}

}