Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Crashpad Authors. All rights reserved. | 1 // Copyright 2014 The Crashpad Authors. All rights reserved. |
| 2 // | 2 // |
| 3 // Licensed under the Apache License, Version 2.0 (the "License"); | 3 // Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 // you may not use this file except in compliance with the License. | 4 // you may not use this file except in compliance with the License. |
| 5 // You may obtain a copy of the License at | 5 // You may obtain a copy of the License at |
| 6 // | 6 // |
| 7 // http://www.apache.org/licenses/LICENSE-2.0 | 7 // http://www.apache.org/licenses/LICENSE-2.0 |
| 8 // | 8 // |
| 9 // Unless required by applicable law or agreed to in writing, software | 9 // Unless required by applicable law or agreed to in writing, software |
| 10 // distributed under the License is distributed on an "AS IS" BASIS, | 10 // distributed under the License is distributed on an "AS IS" BASIS, |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 91 const CompositeHTTPBodyStream::PartsList& parts) | 91 const CompositeHTTPBodyStream::PartsList& parts) |
| 92 : HTTPBodyStream(), parts_(parts), current_part_(parts_.begin()) { | 92 : HTTPBodyStream(), parts_(parts), current_part_(parts_.begin()) { |
| 93 } | 93 } |
| 94 | 94 |
| 95 CompositeHTTPBodyStream::~CompositeHTTPBodyStream() { | 95 CompositeHTTPBodyStream::~CompositeHTTPBodyStream() { |
| 96 STLDeleteContainerPointers(parts_.begin(), parts_.end()); | 96 STLDeleteContainerPointers(parts_.begin(), parts_.end()); |
| 97 } | 97 } |
| 98 | 98 |
| 99 ssize_t CompositeHTTPBodyStream::GetBytesBuffer(uint8_t* buffer, | 99 ssize_t CompositeHTTPBodyStream::GetBytesBuffer(uint8_t* buffer, |
| 100 size_t max_len) { | 100 size_t max_len) { |
| 101 if (current_part_ == parts_.end()) | 101 max_len = |
| 102 return 0; | 102 std::min(max_len, |
|
Mark Mentovai
2014/11/07 17:00:11
Maybe more readable if std::min( went on the first
Robert Sesek
2014/11/07 17:05:33
Done.
| |
| 103 implicit_cast<size_t>(std::numeric_limits<ssize_t>::max())); | |
| 104 size_t bytes_copied = 0; | |
|
Mark Mentovai
2014/11/07 17:00:11
I think this should be ssize_t because that’s what
Robert Sesek
2014/11/07 17:05:33
Done.
| |
| 105 while (bytes_copied < max_len && current_part_ != parts_.end()) { | |
| 106 ssize_t this_read = (*current_part_)->GetBytesBuffer( | |
| 107 buffer + bytes_copied, max_len - bytes_copied); | |
| 103 | 108 |
| 104 ssize_t rv = (*current_part_)->GetBytesBuffer(buffer, max_len); | 109 if (this_read == 0) { |
| 105 | 110 // If the current part has returned 0 indicating EOF, advance the current |
| 106 if (rv == 0) { | 111 // part and try again. |
| 107 // If the current part has returned 0 indicating EOF, advance the current | 112 ++current_part_; |
| 108 // part and call recursively to try again. | 113 } else if (this_read < 0) { |
| 109 ++current_part_; | 114 return this_read; |
| 110 return GetBytesBuffer(buffer, max_len); | 115 } |
| 116 bytes_copied += this_read; | |
| 111 } | 117 } |
| 112 | 118 |
| 113 return rv; | 119 return bytes_copied; |
| 114 } | 120 } |
| 115 | 121 |
| 116 } // namespace crashpad | 122 } // namespace crashpad |
| OLD | NEW |