OLD | NEW |
---|---|
1 {%- import "struct_macros.tmpl" as struct_macros %} | 1 {%- import "struct_macros.tmpl" as struct_macros %} |
2 | 2 |
3 size_t {{struct.name}}::GetSerializedSize() const { | 3 size_t {{struct.name}}::GetSerializedSize() const { |
4 return GetSerializedSize_(*this); | 4 return GetSerializedSize_(*this); |
5 } | 5 } |
6 | 6 |
7 bool {{struct.name}}::Serialize(void* buf, | 7 bool {{struct.name}}::Serialize(void* buf, |
8 size_t buf_size) { | 8 size_t buf_size, |
9 size_t* bytes_written) { | |
10 MOJO_DCHECK(buf); | |
11 | |
9 mojo::internal::FixedBuffer overlay_buf; | 12 mojo::internal::FixedBuffer overlay_buf; |
10 overlay_buf.Initialize(buf, buf_size); | 13 overlay_buf.Initialize(buf, buf_size); |
11 | 14 |
12 internal::{{struct.name}}_Data* output_ptr; | 15 internal::{{struct.name}}_Data* output_ptr; |
13 if (Serialize_(this, &overlay_buf, &output_ptr) != | 16 auto err = Serialize_(this, &overlay_buf, &output_ptr); |
14 mojo::internal::ValidationError::NONE) { | 17 if (err != mojo::internal::ValidationError::NONE) { |
15 // TODO(vardhan): Once Serialize_() outputs handles that it serialized | 18 // TODO(vardhan): Once Serialize_() outputs handles that it serialized |
16 // (even partially, if there are failures), we should CHECK fail here if | 19 // (even partially, if there are failures), we should CHECK fail here if |
17 // handles are non-empty. | 20 // handles are non-empty. |
21 MOJO_DLOG(ERROR) << "Could not serialize: " << | |
22 mojo::internal::ValidationErrorToString(err); | |
23 | |
24 if (bytes_written) | |
25 *bytes_written = overlay_buf.BytesUsed(); | |
18 return false; | 26 return false; |
19 } | 27 } |
20 | 28 |
21 std::vector<mojo::Handle> handles; | 29 std::vector<mojo::Handle> handles; |
22 output_ptr->EncodePointersAndHandles(&handles); | 30 output_ptr->EncodePointersAndHandles(&handles); |
23 | |
24 MOJO_CHECK(handles.empty()) << "Serialize() does not support handles."; | 31 MOJO_CHECK(handles.empty()) << "Serialize() does not support handles."; |
25 | 32 |
33 if (bytes_written) | |
34 *bytes_written = overlay_buf.BytesUsed(); | |
26 return true; | 35 return true; |
27 } | 36 } |
28 | 37 |
29 void {{struct.name}}::Deserialize(void* buf) { | 38 bool {{struct.name}}::Deserialize(void* buf, size_t buf_size) { |
39 MOJO_DCHECK(buf); | |
40 | |
41 mojo::internal::BoundsChecker checker(buf, buf_size, 0); | |
42 std::string err_str; | |
viettrungluu
2016/03/30 17:49:01
You probably shouldn't unconditionally have an |st
vardhan
2016/03/30 22:49:07
Done.
| |
43 mojo::internal::ValidationError err = | |
44 internal::{{struct.name}}_Data::Validate(buf, &checker, &err_str); | |
45 if (err != mojo::internal::ValidationError::NONE) { | |
46 MOJO_DLOG(ERROR) << "Deserialization error " | |
47 << mojo::internal::ValidationErrorToString(err) | |
48 << ": " << err_str; | |
49 return false; | |
50 } | |
51 | |
52 DeserializeWithoutValidation(buf); | |
53 return true; | |
54 } | |
55 | |
56 // TODO(vardhan): Make this |buf| a |const void*| once deserialization becomes | |
57 // immutable. | |
58 void {{struct.name}}::DeserializeWithoutValidation(void* buf) { | |
59 MOJO_DCHECK(buf); | |
60 | |
30 internal::{{struct.name}}_Data* input = | 61 internal::{{struct.name}}_Data* input = |
31 static_cast<internal::{{struct.name}}_Data*>(buf); | 62 static_cast<internal::{{struct.name}}_Data*>(buf); |
32 | |
33 std::vector<mojo::Handle> handles; | 63 std::vector<mojo::Handle> handles; |
34 input->DecodePointersAndHandles(&handles); | 64 input->DecodePointersAndHandles(&handles); |
35 MOJO_CHECK(handles.empty()) << "Deserialize() does not support handles."; | 65 MOJO_CHECK(handles.empty()) << "Deserialization does not support handles."; |
36 | 66 |
37 Deserialize_(input, this); | 67 Deserialize_(input, this); |
38 } | 68 } |
39 | 69 |
40 size_t GetSerializedSize_(const {{struct.name}}& input) { | 70 size_t GetSerializedSize_(const {{struct.name}}& input) { |
41 {{struct_macros.get_serialized_size(struct, "input.%s")}} | 71 {{struct_macros.get_serialized_size(struct, "input.%s")}} |
42 return size; | 72 return size; |
43 } | 73 } |
44 | 74 |
45 mojo::internal::ValidationError Serialize_( | 75 mojo::internal::ValidationError Serialize_( |
46 {{struct.name}}* input, | 76 {{struct.name}}* input, |
47 mojo::internal::Buffer* buf, | 77 mojo::internal::Buffer* buf, |
48 internal::{{struct.name}}_Data** output) { | 78 internal::{{struct.name}}_Data** output) { |
49 if (input) { | 79 if (input) { |
50 {{struct_macros.serialize(struct, struct.name ~ " struct", "input->%s", "res ult", "buf", true)|indent(2)}} | 80 {{struct_macros.serialize(struct, struct.name ~ " struct", "input->%s", "res ult", "buf", true)|indent(2)}} |
51 *output = result; | 81 *output = result; |
52 } else { | 82 } else { |
53 *output = nullptr; | 83 *output = nullptr; |
54 } | 84 } |
55 return mojo::internal::ValidationError::NONE; | 85 return mojo::internal::ValidationError::NONE; |
56 } | 86 } |
57 | 87 |
58 void Deserialize_(internal::{{struct.name}}_Data* input, | 88 void Deserialize_(internal::{{struct.name}}_Data* input, |
59 {{struct.name}}* result) { | 89 {{struct.name}}* result) { |
60 if (input) { | 90 if (input) { |
61 {{struct_macros.deserialize(struct, "input", "result->%s")|indent(2)}} | 91 {{struct_macros.deserialize(struct, "input", "result->%s")|indent(2)}} |
62 } | 92 } |
63 } | 93 } |
OLD | NEW |