Commit 17ded826 authored by Jon Skeet's avatar Jon Skeet

Fix issue 10 - check serialized size before writing to stream

parent ae9b3ff2
...@@ -146,6 +146,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -146,6 +146,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasNumber) { if (HasNumber) {
output.WriteString(1, Number); output.WriteString(1, Number);
} }
...@@ -418,6 +419,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -418,6 +419,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -755,6 +757,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -755,6 +757,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
foreach (global::Google.ProtocolBuffers.Examples.AddressBook.Person element in PersonList) { foreach (global::Google.ProtocolBuffers.Examples.AddressBook.Person element in PersonList) {
output.WriteMessage(1, element); output.WriteMessage(1, element);
} }
......
...@@ -193,6 +193,8 @@ namespace Google.ProtocolBuffers.ProtoGen { ...@@ -193,6 +193,8 @@ namespace Google.ProtocolBuffers.ProtoGen {
writer.WriteLine("public override void WriteTo(pb::CodedOutputStream output) {"); writer.WriteLine("public override void WriteTo(pb::CodedOutputStream output) {");
writer.Indent(); writer.Indent();
// Make sure we've computed the serialized length, so that packed fields are generated correctly.
writer.WriteLine("int size = SerializedSize;");
if (Descriptor.Proto.ExtensionRangeList.Count > 0) { if (Descriptor.Proto.ExtensionRangeList.Count > 0) {
writer.WriteLine("pb::ExtendableMessage<{0}, {0}.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);", writer.WriteLine("pb::ExtendableMessage<{0}, {0}.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);",
ClassName); ClassName);
......
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#endregion #endregion
using System.IO;
using Google.ProtocolBuffers.Descriptors; using Google.ProtocolBuffers.Descriptors;
using Google.ProtocolBuffers.TestProtos; using Google.ProtocolBuffers.TestProtos;
using NUnit.Framework; using NUnit.Framework;
...@@ -313,6 +314,16 @@ namespace Google.ProtocolBuffers { ...@@ -313,6 +314,16 @@ namespace Google.ProtocolBuffers {
Assert.AreEqual("Message missing required fields: a, b, c", e.Message); Assert.AreEqual("Message missing required fields: a, b, c", e.Message);
} }
} }
[Test]
public void PackedTypesWrittenDirectlyToStream() {
TestPackedTypes message = new TestPackedTypes.Builder {PackedInt32List = {0, 1, 2}}.Build();
MemoryStream stream = new MemoryStream();
message.WriteTo(stream);
stream.Position = 0;
TestPackedTypes readMessage = TestPackedTypes.ParseFrom(stream);
Assert.AreEqual(message, readMessage);
}
} }
} }
...@@ -110,6 +110,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -110,6 +110,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasNormal) { if (HasNormal) {
output.WriteString(1, Normal); output.WriteString(1, Normal);
} }
......
...@@ -432,6 +432,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -432,6 +432,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasField1) { if (HasField1) {
output.WriteString(1, Field1); output.WriteString(1, Field1);
} }
...@@ -637,6 +638,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -637,6 +638,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -810,6 +812,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -810,6 +812,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -993,6 +996,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -993,6 +996,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -1166,6 +1170,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1166,6 +1170,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -1339,6 +1344,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1339,6 +1344,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -1512,6 +1518,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1512,6 +1518,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -1685,6 +1692,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1685,6 +1692,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -1858,6 +1866,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1858,6 +1866,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -2031,6 +2040,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -2031,6 +2040,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -2215,6 +2225,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -2215,6 +2225,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<ComplexOptionType1, ComplexOptionType1.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<ComplexOptionType1, ComplexOptionType1.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
if (HasFoo) { if (HasFoo) {
output.WriteInt32(1, Foo); output.WriteInt32(1, Foo);
...@@ -2459,6 +2470,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -2459,6 +2470,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasWaldo) { if (HasWaldo) {
output.WriteInt32(1, Waldo); output.WriteInt32(1, Waldo);
} }
...@@ -2678,6 +2690,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -2678,6 +2690,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<ComplexOptionType2, ComplexOptionType2.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<ComplexOptionType2, ComplexOptionType2.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
if (HasBar) { if (HasBar) {
output.WriteMessage(1, Bar); output.WriteMessage(1, Bar);
...@@ -3028,6 +3041,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -3028,6 +3041,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasPlugh) { if (HasPlugh) {
output.WriteInt32(3, Plugh); output.WriteInt32(3, Plugh);
} }
...@@ -3233,6 +3247,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -3233,6 +3247,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasQux) { if (HasQux) {
output.WriteInt32(1, Qux); output.WriteInt32(1, Qux);
} }
...@@ -3501,6 +3516,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -3501,6 +3516,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasXyzzy) { if (HasXyzzy) {
output.WriteInt32(7593951, Xyzzy); output.WriteInt32(7593951, Xyzzy);
} }
...@@ -3705,6 +3721,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -3705,6 +3721,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
......
...@@ -112,6 +112,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -112,6 +112,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasOptionalMessage) { if (HasOptionalMessage) {
output.WriteMessage(1, OptionalMessage); output.WriteMessage(1, OptionalMessage);
} }
......
...@@ -99,6 +99,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -99,6 +99,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasD) { if (HasD) {
output.WriteInt32(1, D); output.WriteInt32(1, D);
} }
......
...@@ -124,6 +124,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -124,6 +124,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<TestMessageSet, TestMessageSet.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<TestMessageSet, TestMessageSet.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
extensionWriter.WriteUntil(536870912, output); extensionWriter.WriteUntil(536870912, output);
UnknownFields.WriteAsMessageSetTo(output); UnknownFields.WriteAsMessageSetTo(output);
...@@ -311,6 +312,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -311,6 +312,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasMessageSet) { if (HasMessageSet) {
output.WriteMessage(1, MessageSet); output.WriteMessage(1, MessageSet);
} }
...@@ -550,6 +552,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -550,6 +552,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasI) { if (HasI) {
output.WriteInt32(15, I); output.WriteInt32(15, I);
} }
...@@ -766,6 +769,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -766,6 +769,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasStr) { if (HasStr) {
output.WriteString(25, Str); output.WriteString(25, Str);
} }
...@@ -1017,6 +1021,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1017,6 +1021,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasTypeId) { if (HasTypeId) {
output.WriteInt32(2, TypeId); output.WriteInt32(2, TypeId);
} }
...@@ -1246,6 +1251,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1246,6 +1251,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
foreach (global::Google.ProtocolBuffers.TestProtos.RawMessageSet.Types.Item element in ItemList) { foreach (global::Google.ProtocolBuffers.TestProtos.RawMessageSet.Types.Item element in ItemList) {
output.WriteGroup(1, element); output.WriteGroup(1, element);
} }
......
...@@ -989,6 +989,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -989,6 +989,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasBb) { if (HasBb) {
output.WriteInt32(1, Bb); output.WriteInt32(1, Bb);
} }
...@@ -1203,6 +1204,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1203,6 +1204,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(17, A); output.WriteInt32(17, A);
} }
...@@ -1417,6 +1419,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -1417,6 +1419,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(47, A); output.WriteInt32(47, A);
} }
...@@ -2346,6 +2349,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -2346,6 +2349,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasOptionalInt32) { if (HasOptionalInt32) {
output.WriteInt32(1, OptionalInt32); output.WriteInt32(1, OptionalInt32);
} }
...@@ -5257,6 +5261,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -5257,6 +5261,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasC) { if (HasC) {
output.WriteInt32(1, C); output.WriteInt32(1, C);
} }
...@@ -5462,6 +5467,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -5462,6 +5467,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<TestAllExtensions, TestAllExtensions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<TestAllExtensions, TestAllExtensions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
extensionWriter.WriteUntil(536870912, output); extensionWriter.WriteUntil(536870912, output);
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
...@@ -5649,6 +5655,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -5649,6 +5655,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(17, A); output.WriteInt32(17, A);
} }
...@@ -5863,6 +5870,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -5863,6 +5870,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(47, A); output.WriteInt32(47, A);
} }
...@@ -6404,6 +6412,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -6404,6 +6412,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(1, A); output.WriteInt32(1, A);
} }
...@@ -7638,6 +7647,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -7638,6 +7647,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasOptionalMessage) { if (HasOptionalMessage) {
output.WriteMessage(1, OptionalMessage); output.WriteMessage(1, OptionalMessage);
} }
...@@ -7960,6 +7970,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -7960,6 +7970,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasForeignNested) { if (HasForeignNested) {
output.WriteMessage(1, ForeignNested); output.WriteMessage(1, ForeignNested);
} }
...@@ -8187,6 +8198,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -8187,6 +8198,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -8361,6 +8373,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -8361,6 +8373,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<TestEmptyMessageWithExtensions, TestEmptyMessageWithExtensions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<TestEmptyMessageWithExtensions, TestEmptyMessageWithExtensions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
extensionWriter.WriteUntil(536870912, output); extensionWriter.WriteUntil(536870912, output);
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
...@@ -8558,6 +8571,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -8558,6 +8571,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(1, A); output.WriteInt32(1, A);
} }
...@@ -8813,6 +8827,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -8813,6 +8827,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteMessage(1, A); output.WriteMessage(1, A);
} }
...@@ -9081,6 +9096,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -9081,6 +9096,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasBb) { if (HasBb) {
output.WriteMessage(1, Bb); output.WriteMessage(1, Bb);
} }
...@@ -9328,6 +9344,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -9328,6 +9344,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteMessage(1, A); output.WriteMessage(1, A);
} }
...@@ -9620,6 +9637,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -9620,6 +9637,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(1, A); output.WriteInt32(1, A);
} }
...@@ -9834,6 +9852,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -9834,6 +9852,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(1, A); output.WriteInt32(1, A);
} }
...@@ -10049,6 +10068,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -10049,6 +10068,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasA) { if (HasA) {
output.WriteInt32(1, A); output.WriteInt32(1, A);
} }
...@@ -10409,6 +10429,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -10409,6 +10429,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (nestedmessageRepeatedInt32_.Count > 0) { if (nestedmessageRepeatedInt32_.Count > 0) {
foreach (int element in nestedmessageRepeatedInt32_) { foreach (int element in nestedmessageRepeatedInt32_) {
output.WriteInt32(1, element); output.WriteInt32(1, element);
...@@ -10674,6 +10695,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -10674,6 +10695,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasOptionalNestedMessage) { if (HasOptionalNestedMessage) {
output.WriteMessage(1, OptionalNestedMessage); output.WriteMessage(1, OptionalNestedMessage);
} }
...@@ -11033,6 +11055,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -11033,6 +11055,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasPrimitiveField) { if (HasPrimitiveField) {
output.WriteInt32(1, PrimitiveField); output.WriteInt32(1, PrimitiveField);
} }
...@@ -11762,6 +11785,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -11762,6 +11785,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<TestFieldOrderings, TestFieldOrderings.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<TestFieldOrderings, TestFieldOrderings.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
if (HasMyInt) { if (HasMyInt) {
output.WriteInt64(1, MyInt); output.WriteInt64(1, MyInt);
...@@ -12096,6 +12120,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -12096,6 +12120,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasEscapedBytes) { if (HasEscapedBytes) {
output.WriteBytes(1, EscapedBytes); output.WriteBytes(1, EscapedBytes);
} }
...@@ -12651,6 +12676,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -12651,6 +12676,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (packedInt32_.Count > 0) { if (packedInt32_.Count > 0) {
output.WriteRawVarint32(722); output.WriteRawVarint32(722);
output.WriteRawVarint32((uint) packedInt32MemoizedSerializedSize); output.WriteRawVarint32((uint) packedInt32MemoizedSerializedSize);
...@@ -13638,6 +13664,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -13638,6 +13664,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<TestPackedExtensions, TestPackedExtensions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<TestPackedExtensions, TestPackedExtensions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
extensionWriter.WriteUntil(536870912, output); extensionWriter.WriteUntil(536870912, output);
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
...@@ -13815,6 +13842,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -13815,6 +13842,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -13988,6 +14016,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -13988,6 +14016,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -14161,6 +14190,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -14161,6 +14190,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
...@@ -14334,6 +14364,7 @@ namespace Google.ProtocolBuffers.TestProtos { ...@@ -14334,6 +14364,7 @@ namespace Google.ProtocolBuffers.TestProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
UnknownFields.WriteTo(output); UnknownFields.WriteTo(output);
} }
......
...@@ -169,6 +169,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -169,6 +169,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasNamespace) { if (HasNamespace) {
output.WriteString(1, Namespace); output.WriteString(1, Namespace);
} }
...@@ -571,6 +572,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -571,6 +572,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasPropertyName) { if (HasPropertyName) {
output.WriteString(1, PropertyName); output.WriteString(1, PropertyName);
} }
......
...@@ -264,6 +264,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -264,6 +264,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
foreach (global::Google.ProtocolBuffers.DescriptorProtos.FileDescriptorProto element in FileList) { foreach (global::Google.ProtocolBuffers.DescriptorProtos.FileDescriptorProto element in FileList) {
output.WriteMessage(1, element); output.WriteMessage(1, element);
} }
...@@ -596,6 +597,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -596,6 +597,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -1196,6 +1198,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -1196,6 +1198,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasStart) { if (HasStart) {
output.WriteInt32(1, Start); output.WriteInt32(1, Start);
} }
...@@ -1507,6 +1510,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -1507,6 +1510,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -2151,6 +2155,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -2151,6 +2155,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -2653,6 +2658,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -2653,6 +2658,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -2999,6 +3005,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -2999,6 +3005,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -3327,6 +3334,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -3327,6 +3334,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -3683,6 +3691,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -3683,6 +3691,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasName) { if (HasName) {
output.WriteString(1, Name); output.WriteString(1, Name);
} }
...@@ -4072,6 +4081,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -4072,6 +4081,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<FileOptions, FileOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<FileOptions, FileOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
if (HasJavaPackage) { if (HasJavaPackage) {
output.WriteString(1, JavaPackage); output.WriteString(1, JavaPackage);
...@@ -4463,6 +4473,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -4463,6 +4473,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<MessageOptions, MessageOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<MessageOptions, MessageOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
if (HasMessageSetWireFormat) { if (HasMessageSetWireFormat) {
output.WriteBool(1, MessageSetWireFormat); output.WriteBool(1, MessageSetWireFormat);
...@@ -4791,6 +4802,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -4791,6 +4802,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<FieldOptions, FieldOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<FieldOptions, FieldOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
if (HasCtype) { if (HasCtype) {
output.WriteEnum(1, (int) Ctype); output.WriteEnum(1, (int) Ctype);
...@@ -5171,6 +5183,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -5171,6 +5183,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<EnumOptions, EnumOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<EnumOptions, EnumOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) { foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) {
output.WriteMessage(999, element); output.WriteMessage(999, element);
...@@ -5418,6 +5431,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -5418,6 +5431,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<EnumValueOptions, EnumValueOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<EnumValueOptions, EnumValueOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) { foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) {
output.WriteMessage(999, element); output.WriteMessage(999, element);
...@@ -5665,6 +5679,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -5665,6 +5679,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<ServiceOptions, ServiceOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<ServiceOptions, ServiceOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) { foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) {
output.WriteMessage(999, element); output.WriteMessage(999, element);
...@@ -5912,6 +5927,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -5912,6 +5927,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
pb::ExtendableMessage<MethodOptions, MethodOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this); pb::ExtendableMessage<MethodOptions, MethodOptions.Builder>.ExtensionWriter extensionWriter = CreateExtensionWriter(this);
foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) { foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption element in UninterpretedOptionList) {
output.WriteMessage(999, element); output.WriteMessage(999, element);
...@@ -6189,6 +6205,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -6189,6 +6205,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
if (HasNamePart_) { if (HasNamePart_) {
output.WriteString(1, NamePart_); output.WriteString(1, NamePart_);
} }
...@@ -6472,6 +6489,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos { ...@@ -6472,6 +6489,7 @@ namespace Google.ProtocolBuffers.DescriptorProtos {
} }
public override void WriteTo(pb::CodedOutputStream output) { public override void WriteTo(pb::CodedOutputStream output) {
int size = SerializedSize;
foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption.Types.NamePart element in NameList) { foreach (global::Google.ProtocolBuffers.DescriptorProtos.UninterpretedOption.Types.NamePart element in NameList) {
output.WriteMessage(2, element); output.WriteMessage(2, element);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment