Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef COMPONENTS_TRACING_CORE_PROTO_UTILS_H_ | 5 #ifndef COMPONENTS_TRACING_CORE_PROTO_UTILS_H_ |
| 6 #define COMPONENTS_TRACING_CORE_PROTO_UTILS_H_ | 6 #define COMPONENTS_TRACING_CORE_PROTO_UTILS_H_ |
| 7 | 7 |
| 8 #include <inttypes.h> | 8 #include <inttypes.h> |
| 9 | 9 |
| 10 #include <type_traits> | 10 #include <type_traits> |
| 11 | 11 |
| 12 #include "base/logging.h" | 12 #include "base/logging.h" |
| 13 #include "components/tracing/tracing_export.h" | |
| 13 | 14 |
| 14 namespace tracing { | 15 namespace tracing { |
| 15 namespace v2 { | 16 namespace v2 { |
| 16 namespace proto { | 17 namespace proto { |
| 17 | 18 |
| 18 // See https://developers.google.com/protocol-buffers/docs/encoding wire types. | 19 // See https://developers.google.com/protocol-buffers/docs/encoding wire types. |
| 19 | 20 |
| 20 enum : uint32_t { | 21 enum FieldType : uint32_t { |
|
oystein (OOO til 10th of July)
2016/09/08 22:16:07
Why is this an uint32_t (and hence everywhere Pars
Primiano Tucci (use gerrit)
2016/09/09 14:15:49
So, I was about to switch this to uint8_t after yo
| |
| 21 kFieldTypeVarInt = 0, | 22 kFieldTypeVarInt = 0, |
| 22 kFieldTypeFixed64 = 1, | 23 kFieldTypeFixed64 = 1, |
| 23 kFieldTypeLengthDelimited = 2, | 24 kFieldTypeLengthDelimited = 2, |
| 24 kFieldTypeFixed32 = 5, | 25 kFieldTypeFixed32 = 5, |
| 25 }; | 26 }; |
| 26 | 27 |
| 27 // Maximum message size supported: 256 MiB (4 x 7-bit due to varint encoding). | 28 // Maximum message size supported: 256 MiB (4 x 7-bit due to varint encoding). |
| 28 constexpr size_t kMessageLengthFieldSize = 4; | 29 constexpr size_t kMessageLengthFieldSize = 4; |
| 29 constexpr size_t kMaxMessageLength = (1u << (kMessageLengthFieldSize * 7)) - 1; | 30 constexpr size_t kMaxMessageLength = (1u << (kMessageLengthFieldSize * 7)) - 1; |
| 30 | 31 |
| (...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 87 } | 88 } |
| 88 DCHECK_EQ(0u, value) << "Message is too long"; | 89 DCHECK_EQ(0u, value) << "Message is too long"; |
| 89 } | 90 } |
| 90 | 91 |
| 91 template <uint32_t field_id> | 92 template <uint32_t field_id> |
| 92 void StaticAssertSingleBytePreamble() { | 93 void StaticAssertSingleBytePreamble() { |
| 93 static_assert(field_id < 16, | 94 static_assert(field_id < 16, |
| 94 "Proto field id too big to fit in a single byte preamble"); | 95 "Proto field id too big to fit in a single byte preamble"); |
| 95 }; | 96 }; |
| 96 | 97 |
| 98 // Parses a VarInt from the encoded buffer [start, end). |end| is STL-style and | |
| 99 // points one byte past the end of buffer. | |
| 100 // The parsed int value is stored in the output arg |value|. Returns a pointer | |
| 101 // to the next unconsumed byte (so start < retval <= end). | |
| 102 TRACING_EXPORT const uint8_t* ParseVarInt(const uint8_t* start, | |
| 103 const uint8_t* end, | |
| 104 uint64_t* value); | |
| 105 | |
| 106 // Parses a protobuf field, returning its id, type and value. | |
|
petrcermak
2016/09/08 16:13:25
"returning" is misleading here. The value is not r
Primiano Tucci (use gerrit)
2016/09/09 14:15:49
Done.
| |
| 107 // Returns a pointer to the next unconsumed byte (|start| < retval <= end), that | |
|
petrcermak
2016/09/08 16:13:25
grammar nit: either there shouldn't be a comma or
Primiano Tucci (use gerrit)
2016/09/09 14:15:49
Done.
| |
| 108 // is either the beginning of the next field or the end of the parent message. | |
| 109 // In the case of a kFieldTypeLengthDelimited field |field_intvalue| will store | |
|
petrcermak
2016/09/08 16:13:25
Here, on the other hand, should be a comma after "
Primiano Tucci (use gerrit)
2016/09/09 14:15:49
Done.
| |
| 110 // the length of the payload (either a string or a nested message). In this case | |
|
petrcermak
2016/09/08 16:13:25
nit: there should be a comma after "In this case"
Primiano Tucci (use gerrit)
2016/09/09 14:15:49
Done.
| |
| 111 // the start of the payload will be at (return value) - |field_intvalue|. | |
| 112 TRACING_EXPORT const uint8_t* ParseField(const uint8_t* start, | |
| 113 const uint8_t* end, | |
| 114 uint32_t* field_id, | |
| 115 FieldType* field_type, | |
| 116 uint64_t* field_intvalue); | |
| 117 | |
| 97 } // namespace proto | 118 } // namespace proto |
| 98 } // namespace v2 | 119 } // namespace v2 |
| 99 } // namespace tracing | 120 } // namespace tracing |
| 100 | 121 |
| 101 #endif // COMPONENTS_TRACING_CORE_PROTO_UTILS_H_ | 122 #endif // COMPONENTS_TRACING_CORE_PROTO_UTILS_H_ |
| OLD | NEW |