// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "net/base/upload_bytes_element_reader.h"
#include "base/logging.h"
#include "base/stl_util.h"
#include "net/base/io_buffer.h"
#include "net/base/net_errors.h"
namespace net {
UploadBytesElementReader::UploadBytesElementReader(const char* bytes,
uint64 length)
: bytes_(bytes),
length_(length),
offset_(0) {
}
UploadBytesElementReader::~UploadBytesElementReader() {
}
const UploadBytesElementReader*
UploadBytesElementReader::AsBytesReader() const {
return this;
}
int UploadBytesElementReader::Init(const CompletionCallback& callback) {
offset_ = 0;
return OK;
}
uint64 UploadBytesElementReader::GetContentLength() const {
return length_;
}
uint64 UploadBytesElementReader::BytesRemaining() const {
return length_ - offset_;
}
bool UploadBytesElementReader::IsInMemory() const {
return true;
}
int UploadBytesElementReader::Read(IOBuffer* buf,
int buf_length,
const CompletionCallback& callback) {
DCHECK_LT(0, buf_length);
const size_t num_bytes_to_read =
std::min(BytesRemaining(), static_cast<uint64>(buf_length));
// Check if we have anything to copy first, because we are getting
// the address of an element in |bytes_| and that will throw an
// exception if |bytes_| is an empty vector.
if (num_bytes_to_read > 0)
memcpy(buf->data(), bytes_ + offset_, num_bytes_to_read);
offset_ += num_bytes_to_read;
return num_bytes_to_read;
}
UploadOwnedBytesElementReader::UploadOwnedBytesElementReader(
std::vector<char>* data)
: UploadBytesElementReader(vector_as_array(data), data->size()) {
data_.swap(*data);
}
UploadOwnedBytesElementReader::~UploadOwnedBytesElementReader() {}
UploadOwnedBytesElementReader*
UploadOwnedBytesElementReader::CreateWithString(const std::string& string) {
std::vector<char> data(string.begin(), string.end());
return new UploadOwnedBytesElementReader(&data);
}
} // namespace net