diff options
author | Remko Tronçon <git@el-tramo.be> | 2011-09-30 18:46:42 (GMT) |
---|---|---|
committer | Remko Tronçon <git@el-tramo.be> | 2011-09-30 18:46:42 (GMT) |
commit | 1b255f6ba90847240b92126deb5ea0174ad269b0 (patch) | |
tree | 9d56e647ebc35c0f0941d19a302b888c1185ce1c /Swiften/FileTransfer/FileReadBytestream.cpp | |
parent | af976a75b5e1b504a340602659ef930109cd2c48 (diff) | |
download | swift-contrib-1b255f6ba90847240b92126deb5ea0174ad269b0.zip swift-contrib-1b255f6ba90847240b92126deb5ea0174ad269b0.tar.bz2 |
Avoid a copy when reading from a byte array.
Diffstat (limited to 'Swiften/FileTransfer/FileReadBytestream.cpp')
-rw-r--r-- | Swiften/FileTransfer/FileReadBytestream.cpp | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/Swiften/FileTransfer/FileReadBytestream.cpp b/Swiften/FileTransfer/FileReadBytestream.cpp index f0139b8..a8946a0 100644 --- a/Swiften/FileTransfer/FileReadBytestream.cpp +++ b/Swiften/FileTransfer/FileReadBytestream.cpp @@ -6,8 +6,10 @@ #include <boost/filesystem/fstream.hpp> #include <cassert> +#include <boost/smart_ptr/make_shared.hpp> #include <Swiften/FileTransfer/FileReadBytestream.h> +#include <Swiften/Base/ByteArray.h> namespace Swift { @@ -21,16 +23,16 @@ FileReadBytestream::~FileReadBytestream() { } } -std::vector<unsigned char> FileReadBytestream::read(size_t size) { +boost::shared_ptr<ByteArray> FileReadBytestream::read(size_t size) { if (!stream) { stream = new boost::filesystem::ifstream(file, std::ios_base::in|std::ios_base::binary); } - std::vector<unsigned char> result; - result.resize(size); + boost::shared_ptr<ByteArray> result = boost::make_shared<ByteArray>(); + result->resize(size); assert(stream->good()); - stream->read(reinterpret_cast<char*>(&result[0]), size); - result.resize(stream->gcount()); - onRead(result); + stream->read(reinterpret_cast<char*>(vecptr(*result)), size); + result->resize(stream->gcount()); + onRead(*result); return result; } |