|
@@ -42,6 +42,7 @@
|
|
|
#include "message.h"
|
|
|
#include "fmt.h"
|
|
|
#include "LogFactory.h"
|
|
|
+#include "a2functional.h"
|
|
|
|
|
|
namespace aria2 {
|
|
|
|
|
@@ -76,9 +77,9 @@ const unsigned char* SocketBuffer::ByteArrayBufEntry::getData() const
|
|
|
return bytes_;
|
|
|
}
|
|
|
|
|
|
-SocketBuffer::StringBufEntry::StringBufEntry(const std::string& s,
|
|
|
+SocketBuffer::StringBufEntry::StringBufEntry(std::string s,
|
|
|
ProgressUpdate* progressUpdate)
|
|
|
- : BufEntry(progressUpdate), str_(s)
|
|
|
+ : BufEntry(progressUpdate), str_(std::move(s))
|
|
|
{}
|
|
|
|
|
|
// SocketBuffer::StringBufEntry::StringBufEntry() {}
|
|
@@ -118,17 +119,16 @@ void SocketBuffer::pushBytes(unsigned char* bytes, size_t len,
|
|
|
ProgressUpdate* progressUpdate)
|
|
|
{
|
|
|
if(len > 0) {
|
|
|
- bufq_.push_back(std::shared_ptr<BufEntry>
|
|
|
- (new ByteArrayBufEntry(bytes, len, progressUpdate)));
|
|
|
+ bufq_.push_back(make_unique<ByteArrayBufEntry>(bytes, len,
|
|
|
+ progressUpdate));
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-void SocketBuffer::pushStr(const std::string& data,
|
|
|
- ProgressUpdate* progressUpdate)
|
|
|
+void SocketBuffer::pushStr(std::string data, ProgressUpdate* progressUpdate)
|
|
|
{
|
|
|
- if(data.size() > 0) {
|
|
|
- bufq_.push_back(std::shared_ptr<BufEntry>
|
|
|
- (new StringBufEntry(data, progressUpdate)));
|
|
|
+ if(!data.empty()) {
|
|
|
+ bufq_.push_back(make_unique<StringBufEntry>(std::move(data),
|
|
|
+ progressUpdate));
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -138,21 +138,23 @@ ssize_t SocketBuffer::send()
|
|
|
size_t totalslen = 0;
|
|
|
while(!bufq_.empty()) {
|
|
|
size_t num;
|
|
|
+ size_t bufqlen = bufq_.size();
|
|
|
ssize_t amount = 24*1024;
|
|
|
- ssize_t firstlen = bufq_[0]->getLength() - offset_;
|
|
|
+ ssize_t firstlen = bufq_.front()->getLength() - offset_;
|
|
|
amount -= firstlen;
|
|
|
iov[0].A2IOVEC_BASE =
|
|
|
reinterpret_cast<char*>(const_cast<unsigned char*>
|
|
|
- (bufq_[0]->getData() + offset_));
|
|
|
+ (bufq_.front()->getData() + offset_));
|
|
|
iov[0].A2IOVEC_LEN = firstlen;
|
|
|
-
|
|
|
- for(num = 1; num < A2_IOV_MAX && num < bufq_.size() && amount > 0; ++num) {
|
|
|
- const std::shared_ptr<BufEntry>& buf = bufq_[num];
|
|
|
- ssize_t len = buf->getLength();
|
|
|
+ num = 1;
|
|
|
+ for(auto i = std::begin(bufq_)+1, eoi = std::end(bufq_);
|
|
|
+ i != eoi && num < A2_IOV_MAX && num < bufqlen && amount > 0;
|
|
|
+ ++i, ++num) {
|
|
|
+ ssize_t len = (*i)->getLength();
|
|
|
if(amount >= len) {
|
|
|
amount -= len;
|
|
|
iov[num].A2IOVEC_BASE =
|
|
|
- reinterpret_cast<char*>(const_cast<unsigned char*>(buf->getData()));
|
|
|
+ reinterpret_cast<char*>(const_cast<unsigned char*>((*i)->getData()));
|
|
|
iov[num].A2IOVEC_LEN = len;
|
|
|
} else {
|
|
|
break;
|
|
@@ -168,24 +170,24 @@ ssize_t SocketBuffer::send()
|
|
|
|
|
|
if(firstlen > slen) {
|
|
|
offset_ += slen;
|
|
|
- bufq_[0]->progressUpdate(slen, false);
|
|
|
+ bufq_.front()->progressUpdate(slen, false);
|
|
|
goto fin;
|
|
|
} else {
|
|
|
slen -= firstlen;
|
|
|
- bufq_[0]->progressUpdate(firstlen, true);
|
|
|
+ bufq_.front()->progressUpdate(firstlen, true);
|
|
|
bufq_.pop_front();
|
|
|
offset_ = 0;
|
|
|
for(size_t i = 1; i < num; ++i) {
|
|
|
- const std::shared_ptr<BufEntry>& buf = bufq_[0];
|
|
|
+ const std::unique_ptr<BufEntry>& buf = bufq_.front();
|
|
|
ssize_t len = buf->getLength();
|
|
|
if(len > slen) {
|
|
|
offset_ = slen;
|
|
|
- bufq_[0]->progressUpdate(slen, false);
|
|
|
+ bufq_.front()->progressUpdate(slen, false);
|
|
|
goto fin;
|
|
|
break;
|
|
|
} else {
|
|
|
slen -= len;
|
|
|
- bufq_[0]->progressUpdate(len, true);
|
|
|
+ bufq_.front()->progressUpdate(len, true);
|
|
|
bufq_.pop_front();
|
|
|
}
|
|
|
}
|