Chromium Code Reviews| Index: net/quic/quic_data_writer.cc | 
| diff --git a/net/quic/quic_data_writer.cc b/net/quic/quic_data_writer.cc | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..41c80fe315bc12768750a786e8afb91d363b54c9 | 
| --- /dev/null | 
| +++ b/net/quic/quic_data_writer.cc | 
| @@ -0,0 +1,69 @@ | 
| +// 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/quic/quic_data_writer.h" | 
| + | 
| +#include <algorithm> | 
| +#include <limits> | 
| + | 
| +#include "base/basictypes.h" | 
| +#include "base/logging.h" | 
| +#include "net/quic/quic_protocol.h" | 
| + | 
| +using std::numeric_limits; | 
| + | 
| +namespace net { | 
| + | 
| +QuicDataWriter::QuicDataWriter(size_t size) | 
| + : buffer_(new char[size]), | 
| 
 
jar (doing other things)
2012/10/14 23:04:38
nit/comment: It is a bit tempting to have a fixed
 
Ryan Hamilton
2012/10/15 21:22:08
But then the take() method could not be implemente
 
 | 
| + capacity_(size), | 
| + length_(0) { | 
| +} | 
| + | 
| +QuicDataWriter::~QuicDataWriter() { | 
| + delete[] buffer_; | 
| +} | 
| + | 
| +char* QuicDataWriter::BeginWrite(size_t length) { | 
| + size_t offset = length_; | 
| + size_t needed_size = length_ + length; | 
| + if (needed_size > capacity_) { | 
| 
 
jar (doing other things)
2012/10/14 23:04:38
nit: to handle wrapping, perhaps better would be:
 
Ryan Hamilton
2012/10/15 21:22:08
Done.  FYI, This code was simply copied from the s
 
 | 
| + return NULL; | 
| + } | 
| + | 
| +#ifdef ARCH_CPU_64_BITS | 
| + DCHECK_LE(length, numeric_limits<uint32>::max()); | 
| +#endif | 
| + | 
| + return buffer_ + offset; | 
| 
 
jar (doing other things)
2012/10/14 23:04:38
Why did you save length_ into offset?  Isn't this
 
Ryan Hamilton
2012/10/15 21:22:08
This code was copied from the spdy variant.
 
 | 
| +} | 
| + | 
| +bool QuicDataWriter::AdvancePointer(uint32 len) { | 
| + if (!BeginWrite(len)) return false; | 
| 
 
jar (doing other things)
2012/10/14 23:04:38
nit: probably want to be consistent with braces an
 
Ryan Hamilton
2012/10/15 21:22:08
Done.  But just to be clear, this is perfectly acc
 
 | 
| + length_ += len; | 
| + return true; | 
| +} | 
| + | 
| +bool QuicDataWriter::WriteBytes(const void* data, uint32 data_len) { | 
| + char* dest = BeginWrite(data_len); | 
| + if (!dest) { | 
| + return false; | 
| + } | 
| + | 
| + memcpy(dest, data, data_len); | 
| + | 
| + length_ += data_len; | 
| + return true; | 
| +} | 
| + | 
| +void QuicDataWriter::WriteUint64ToBuffer(uint64 value, char* buffer) { | 
| + memcpy(buffer, &value, sizeof(value)); | 
| +} | 
| + | 
| +void QuicDataWriter::WriteUint128ToBuffer(uint128 value, char* buffer) { | 
| + WriteUint64ToBuffer(value.lo, buffer); | 
| + WriteUint64ToBuffer(value.hi, buffer + sizeof(value.lo)); | 
| +} | 
| + | 
| +} // namespace net |