Commit 6c1fe6ea authored by Jon Skeet's avatar Jon Skeet

Implement Clone.

Fixes issue #527.
parent 45b70328
...@@ -62,7 +62,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -62,7 +62,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
#region Messages #region Messages
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class Person : pb::IMessage<Person>, global::System.IEquatable<Person> { public sealed partial class Person : pb::IMessage<Person>, global::System.IEquatable<Person>, pb::IDeepCloneable<Person> {
private static readonly pb::MessageParser<Person> _parser = new pb::MessageParser<Person>(() => new Person()); private static readonly pb::MessageParser<Person> _parser = new pb::MessageParser<Person>(() => new Person());
public static pb::MessageParser<Person> Parser { get { return _parser; } } public static pb::MessageParser<Person> Parser { get { return _parser; } }
...@@ -77,9 +77,18 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -77,9 +77,18 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
public Person() { } public Person() { }
public Person(Person other) { public Person(Person other) {
MergeFrom(other); name_ = other.name_;
id_ = other.id_;
email_ = other.email_;
phone_ = other.phone_.Clone();
}
public Person Clone() {
return new Person(this);
} }
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -231,7 +240,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -231,7 +240,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class PhoneNumber : pb::IMessage<PhoneNumber>, global::System.IEquatable<PhoneNumber> { public sealed partial class PhoneNumber : pb::IMessage<PhoneNumber>, global::System.IEquatable<PhoneNumber>, pb::IDeepCloneable<PhoneNumber> {
private static readonly pb::MessageParser<PhoneNumber> _parser = new pb::MessageParser<PhoneNumber>(() => new PhoneNumber()); private static readonly pb::MessageParser<PhoneNumber> _parser = new pb::MessageParser<PhoneNumber>(() => new PhoneNumber());
public static pb::MessageParser<PhoneNumber> Parser { get { return _parser; } } public static pb::MessageParser<PhoneNumber> Parser { get { return _parser; } }
...@@ -246,9 +255,16 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -246,9 +255,16 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
public PhoneNumber() { } public PhoneNumber() { }
public PhoneNumber(PhoneNumber other) { public PhoneNumber(PhoneNumber other) {
MergeFrom(other); number_ = other.number_;
type_ = other.type_;
}
public PhoneNumber Clone() {
return new PhoneNumber(this);
} }
public const int NumberFieldNumber = 1; public const int NumberFieldNumber = 1;
private string number_ = ""; private string number_ = "";
public string Number { public string Number {
...@@ -352,7 +368,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -352,7 +368,7 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class AddressBook : pb::IMessage<AddressBook>, global::System.IEquatable<AddressBook> { public sealed partial class AddressBook : pb::IMessage<AddressBook>, global::System.IEquatable<AddressBook>, pb::IDeepCloneable<AddressBook> {
private static readonly pb::MessageParser<AddressBook> _parser = new pb::MessageParser<AddressBook>(() => new AddressBook()); private static readonly pb::MessageParser<AddressBook> _parser = new pb::MessageParser<AddressBook>(() => new AddressBook());
public static pb::MessageParser<AddressBook> Parser { get { return _parser; } } public static pb::MessageParser<AddressBook> Parser { get { return _parser; } }
...@@ -367,9 +383,15 @@ namespace Google.ProtocolBuffers.Examples.AddressBook { ...@@ -367,9 +383,15 @@ namespace Google.ProtocolBuffers.Examples.AddressBook {
} }
public AddressBook() { } public AddressBook() { }
public AddressBook(AddressBook other) { public AddressBook(AddressBook other) {
MergeFrom(other); person_ = other.person_.Clone();
} }
public AddressBook Clone() {
return new AddressBook(this);
}
public const int PersonFieldNumber = 1; public const int PersonFieldNumber = 1;
private readonly pbc::RepeatedField<global::Google.ProtocolBuffers.Examples.AddressBook.Person> person_ = new pbc::RepeatedField<global::Google.ProtocolBuffers.Examples.AddressBook.Person>(); private readonly pbc::RepeatedField<global::Google.ProtocolBuffers.Examples.AddressBook.Person> person_ = new pbc::RepeatedField<global::Google.ProtocolBuffers.Examples.AddressBook.Person>();
public pbc::RepeatedField<global::Google.ProtocolBuffers.Examples.AddressBook.Person> Person { public pbc::RepeatedField<global::Google.ProtocolBuffers.Examples.AddressBook.Person> Person {
......
using System; using Google.Protobuf.TestProtos;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Google.Protobuf.TestProtos;
using NUnit.Framework; using NUnit.Framework;
namespace Google.Protobuf namespace Google.Protobuf
...@@ -88,7 +83,7 @@ namespace Google.Protobuf ...@@ -88,7 +83,7 @@ namespace Google.Protobuf
var message = new TestAllTypes var message = new TestAllTypes
{ {
SingleBool = true, SingleBool = true,
SingleBytes = ByteString.CopyFrom(new byte[] { 1, 2, 3, 4 }), SingleBytes = ByteString.CopyFrom(1, 2, 3, 4),
SingleDouble = 23.5, SingleDouble = 23.5,
SingleFixed32 = 23, SingleFixed32 = 23,
SingleFixed64 = 1234567890123, SingleFixed64 = 1234567890123,
...@@ -122,7 +117,7 @@ namespace Google.Protobuf ...@@ -122,7 +117,7 @@ namespace Google.Protobuf
var message = new TestAllTypes var message = new TestAllTypes
{ {
RepeatedBool = { true, false }, RepeatedBool = { true, false },
RepeatedBytes = { ByteString.CopyFrom(new byte[] { 1, 2, 3, 4 }), ByteString.CopyFrom(new byte[] { 5, 6 }) }, RepeatedBytes = { ByteString.CopyFrom(1, 2, 3, 4), ByteString.CopyFrom(5, 6) },
RepeatedDouble = { -12.25, 23.5 }, RepeatedDouble = { -12.25, 23.5 },
RepeatedFixed32 = { uint.MaxValue, 23 }, RepeatedFixed32 = { uint.MaxValue, 23 },
RepeatedFixed64 = { ulong.MaxValue, 1234567890123 }, RepeatedFixed64 = { ulong.MaxValue, 1234567890123 },
...@@ -149,5 +144,118 @@ namespace Google.Protobuf ...@@ -149,5 +144,118 @@ namespace Google.Protobuf
TestAllTypes parsed = TestAllTypes.Parser.ParseFrom(bytes); TestAllTypes parsed = TestAllTypes.Parser.ParseFrom(bytes);
Assert.AreEqual(message, parsed); Assert.AreEqual(message, parsed);
} }
[Test]
public void CloneSingleNonMessageValues()
{
var original = new TestAllTypes
{
SingleBool = true,
SingleBytes = ByteString.CopyFrom(1, 2, 3, 4),
SingleDouble = 23.5,
SingleFixed32 = 23,
SingleFixed64 = 1234567890123,
SingleFloat = 12.25f,
SingleInt32 = 100,
SingleInt64 = 3210987654321,
SingleNestedEnum = TestAllTypes.Types.NestedEnum.FOO,
SingleSfixed32 = -123,
SingleSfixed64 = -12345678901234,
SingleSint32 = -456,
SingleSint64 = -12345678901235,
SingleString = "test",
SingleUint32 = uint.MaxValue,
SingleUint64 = ulong.MaxValue
};
var clone = original.Clone();
Assert.AreNotSame(original, clone);
Assert.AreEqual(original, clone);
// Just as a single example
clone.SingleInt32 = 150;
Assert.AreNotEqual(original, clone);
}
[Test]
public void CloneRepeatedNonMessageValues()
{
var original = new TestAllTypes
{
RepeatedBool = { true, false },
RepeatedBytes = { ByteString.CopyFrom(1, 2, 3, 4), ByteString.CopyFrom(5, 6) },
RepeatedDouble = { -12.25, 23.5 },
RepeatedFixed32 = { uint.MaxValue, 23 },
RepeatedFixed64 = { ulong.MaxValue, 1234567890123 },
RepeatedFloat = { 100f, 12.25f },
RepeatedInt32 = { 100, 200 },
RepeatedInt64 = { 3210987654321, long.MaxValue },
RepeatedNestedEnum = { TestAllTypes.Types.NestedEnum.FOO, TestAllTypes.Types.NestedEnum.NEG },
RepeatedSfixed32 = { -123, 123 },
RepeatedSfixed64 = { -12345678901234, 12345678901234 },
RepeatedSint32 = { -456, 100 },
RepeatedSint64 = { -12345678901235, 123 },
RepeatedString = { "foo", "bar" },
RepeatedUint32 = { uint.MaxValue, uint.MinValue },
RepeatedUint64 = { ulong.MaxValue, uint.MinValue }
};
var clone = original.Clone();
Assert.AreNotSame(original, clone);
Assert.AreEqual(original, clone);
// Just as a single example
clone.RepeatedDouble.Add(25.5);
Assert.AreNotEqual(original, clone);
}
[Test]
public void CloneSingleMessageField()
{
var original = new TestAllTypes
{
SingleNestedMessage = new TestAllTypes.Types.NestedMessage { Bb = 20 }
};
var clone = original.Clone();
Assert.AreNotSame(original, clone);
Assert.AreNotSame(original.SingleNestedMessage, clone.SingleNestedMessage);
Assert.AreEqual(original, clone);
clone.SingleNestedMessage.Bb = 30;
Assert.AreNotEqual(original, clone);
}
[Test]
public void CloneRepeatedMessageField()
{
var original = new TestAllTypes
{
RepeatedNestedMessage = { new TestAllTypes.Types.NestedMessage { Bb = 20 } }
};
var clone = original.Clone();
Assert.AreNotSame(original, clone);
Assert.AreNotSame(original.RepeatedNestedMessage, clone.RepeatedNestedMessage);
Assert.AreNotSame(original.RepeatedNestedMessage[0], clone.RepeatedNestedMessage[0]);
Assert.AreEqual(original, clone);
clone.RepeatedNestedMessage[0].Bb = 30;
Assert.AreNotEqual(original, clone);
}
[Test]
public void CloneOneofField()
{
var original = new TestAllTypes
{
OneofNestedMessage = new TestAllTypes.Types.NestedMessage { Bb = 20 }
};
var clone = original.Clone();
Assert.AreNotSame(original, clone);
Assert.AreEqual(original, clone);
// We should have cloned the message
original.OneofNestedMessage.Bb = 30;
Assert.AreNotEqual(original, clone);
}
} }
} }
...@@ -60,7 +60,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -60,7 +60,7 @@ namespace Google.Protobuf.TestProtos {
#region Messages #region Messages
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class ImportMessage : pb::IMessage<ImportMessage>, global::System.IEquatable<ImportMessage> { public sealed partial class ImportMessage : pb::IMessage<ImportMessage>, global::System.IEquatable<ImportMessage>, pb::IDeepCloneable<ImportMessage> {
private static readonly pb::MessageParser<ImportMessage> _parser = new pb::MessageParser<ImportMessage>(() => new ImportMessage()); private static readonly pb::MessageParser<ImportMessage> _parser = new pb::MessageParser<ImportMessage>(() => new ImportMessage());
public static pb::MessageParser<ImportMessage> Parser { get { return _parser; } } public static pb::MessageParser<ImportMessage> Parser { get { return _parser; } }
...@@ -75,9 +75,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -75,9 +75,15 @@ namespace Google.Protobuf.TestProtos {
} }
public ImportMessage() { } public ImportMessage() { }
public ImportMessage(ImportMessage other) { public ImportMessage(ImportMessage other) {
MergeFrom(other); d_ = other.d_;
}
public ImportMessage Clone() {
return new ImportMessage(this);
} }
public const int DFieldNumber = 1; public const int DFieldNumber = 1;
private int d_; private int d_;
public int D { public int D {
......
...@@ -45,7 +45,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -45,7 +45,7 @@ namespace Google.Protobuf.TestProtos {
} }
#region Messages #region Messages
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class PublicImportMessage : pb::IMessage<PublicImportMessage>, global::System.IEquatable<PublicImportMessage> { public sealed partial class PublicImportMessage : pb::IMessage<PublicImportMessage>, global::System.IEquatable<PublicImportMessage>, pb::IDeepCloneable<PublicImportMessage> {
private static readonly pb::MessageParser<PublicImportMessage> _parser = new pb::MessageParser<PublicImportMessage>(() => new PublicImportMessage()); private static readonly pb::MessageParser<PublicImportMessage> _parser = new pb::MessageParser<PublicImportMessage>(() => new PublicImportMessage());
public static pb::MessageParser<PublicImportMessage> Parser { get { return _parser; } } public static pb::MessageParser<PublicImportMessage> Parser { get { return _parser; } }
...@@ -60,9 +60,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -60,9 +60,15 @@ namespace Google.Protobuf.TestProtos {
} }
public PublicImportMessage() { } public PublicImportMessage() { }
public PublicImportMessage(PublicImportMessage other) { public PublicImportMessage(PublicImportMessage other) {
MergeFrom(other); e_ = other.e_;
}
public PublicImportMessage Clone() {
return new PublicImportMessage(this);
} }
public const int EFieldNumber = 1; public const int EFieldNumber = 1;
private int e_; private int e_;
public int E { public int E {
......
...@@ -90,7 +90,7 @@ namespace UnitTest.Issues.TestProtos { ...@@ -90,7 +90,7 @@ namespace UnitTest.Issues.TestProtos {
#region Messages #region Messages
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class NegativeEnumMessage : pb::IMessage<NegativeEnumMessage>, global::System.IEquatable<NegativeEnumMessage> { public sealed partial class NegativeEnumMessage : pb::IMessage<NegativeEnumMessage>, global::System.IEquatable<NegativeEnumMessage>, pb::IDeepCloneable<NegativeEnumMessage> {
private static readonly pb::MessageParser<NegativeEnumMessage> _parser = new pb::MessageParser<NegativeEnumMessage>(() => new NegativeEnumMessage()); private static readonly pb::MessageParser<NegativeEnumMessage> _parser = new pb::MessageParser<NegativeEnumMessage>(() => new NegativeEnumMessage());
public static pb::MessageParser<NegativeEnumMessage> Parser { get { return _parser; } } public static pb::MessageParser<NegativeEnumMessage> Parser { get { return _parser; } }
...@@ -105,9 +105,17 @@ namespace UnitTest.Issues.TestProtos { ...@@ -105,9 +105,17 @@ namespace UnitTest.Issues.TestProtos {
} }
public NegativeEnumMessage() { } public NegativeEnumMessage() { }
public NegativeEnumMessage(NegativeEnumMessage other) { public NegativeEnumMessage(NegativeEnumMessage other) {
MergeFrom(other); value_ = other.value_;
values_ = other.values_.Clone();
packedValues_ = other.packedValues_.Clone();
}
public NegativeEnumMessage Clone() {
return new NegativeEnumMessage(this);
} }
public const int ValueFieldNumber = 1; public const int ValueFieldNumber = 1;
private global::UnitTest.Issues.TestProtos.NegativeEnum value_ = global::UnitTest.Issues.TestProtos.NegativeEnum.NEGATIVE_ENUM_ZERO; private global::UnitTest.Issues.TestProtos.NegativeEnum value_ = global::UnitTest.Issues.TestProtos.NegativeEnum.NEGATIVE_ENUM_ZERO;
public global::UnitTest.Issues.TestProtos.NegativeEnum Value { public global::UnitTest.Issues.TestProtos.NegativeEnum Value {
...@@ -233,7 +241,7 @@ namespace UnitTest.Issues.TestProtos { ...@@ -233,7 +241,7 @@ namespace UnitTest.Issues.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class DeprecatedChild : pb::IMessage<DeprecatedChild>, global::System.IEquatable<DeprecatedChild> { public sealed partial class DeprecatedChild : pb::IMessage<DeprecatedChild>, global::System.IEquatable<DeprecatedChild>, pb::IDeepCloneable<DeprecatedChild> {
private static readonly pb::MessageParser<DeprecatedChild> _parser = new pb::MessageParser<DeprecatedChild>(() => new DeprecatedChild()); private static readonly pb::MessageParser<DeprecatedChild> _parser = new pb::MessageParser<DeprecatedChild>(() => new DeprecatedChild());
public static pb::MessageParser<DeprecatedChild> Parser { get { return _parser; } } public static pb::MessageParser<DeprecatedChild> Parser { get { return _parser; } }
...@@ -248,9 +256,14 @@ namespace UnitTest.Issues.TestProtos { ...@@ -248,9 +256,14 @@ namespace UnitTest.Issues.TestProtos {
} }
public DeprecatedChild() { } public DeprecatedChild() { }
public DeprecatedChild(DeprecatedChild other) { public DeprecatedChild(DeprecatedChild other) {
MergeFrom(other);
} }
public DeprecatedChild Clone() {
return new DeprecatedChild(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as DeprecatedChild); return Equals(other as DeprecatedChild);
} }
...@@ -301,7 +314,7 @@ namespace UnitTest.Issues.TestProtos { ...@@ -301,7 +314,7 @@ namespace UnitTest.Issues.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class DeprecatedFieldsMessage : pb::IMessage<DeprecatedFieldsMessage>, global::System.IEquatable<DeprecatedFieldsMessage> { public sealed partial class DeprecatedFieldsMessage : pb::IMessage<DeprecatedFieldsMessage>, global::System.IEquatable<DeprecatedFieldsMessage>, pb::IDeepCloneable<DeprecatedFieldsMessage> {
private static readonly pb::MessageParser<DeprecatedFieldsMessage> _parser = new pb::MessageParser<DeprecatedFieldsMessage>(() => new DeprecatedFieldsMessage()); private static readonly pb::MessageParser<DeprecatedFieldsMessage> _parser = new pb::MessageParser<DeprecatedFieldsMessage>(() => new DeprecatedFieldsMessage());
public static pb::MessageParser<DeprecatedFieldsMessage> Parser { get { return _parser; } } public static pb::MessageParser<DeprecatedFieldsMessage> Parser { get { return _parser; } }
...@@ -316,9 +329,20 @@ namespace UnitTest.Issues.TestProtos { ...@@ -316,9 +329,20 @@ namespace UnitTest.Issues.TestProtos {
} }
public DeprecatedFieldsMessage() { } public DeprecatedFieldsMessage() { }
public DeprecatedFieldsMessage(DeprecatedFieldsMessage other) { public DeprecatedFieldsMessage(DeprecatedFieldsMessage other) {
MergeFrom(other); primitiveValue_ = other.primitiveValue_;
primitiveArray_ = other.primitiveArray_.Clone();
MessageValue = other.messageValue_ != null ? other.MessageValue.Clone() : null;
messageArray_ = other.messageArray_.Clone();
enumValue_ = other.enumValue_;
enumArray_ = other.enumArray_.Clone();
}
public DeprecatedFieldsMessage Clone() {
return new DeprecatedFieldsMessage(this);
} }
public const int PrimitiveValueFieldNumber = 1; public const int PrimitiveValueFieldNumber = 1;
private int primitiveValue_; private int primitiveValue_;
[global::System.ObsoleteAttribute()] [global::System.ObsoleteAttribute()]
...@@ -525,7 +549,7 @@ namespace UnitTest.Issues.TestProtos { ...@@ -525,7 +549,7 @@ namespace UnitTest.Issues.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class ItemField : pb::IMessage<ItemField>, global::System.IEquatable<ItemField> { public sealed partial class ItemField : pb::IMessage<ItemField>, global::System.IEquatable<ItemField>, pb::IDeepCloneable<ItemField> {
private static readonly pb::MessageParser<ItemField> _parser = new pb::MessageParser<ItemField>(() => new ItemField()); private static readonly pb::MessageParser<ItemField> _parser = new pb::MessageParser<ItemField>(() => new ItemField());
public static pb::MessageParser<ItemField> Parser { get { return _parser; } } public static pb::MessageParser<ItemField> Parser { get { return _parser; } }
...@@ -540,9 +564,15 @@ namespace UnitTest.Issues.TestProtos { ...@@ -540,9 +564,15 @@ namespace UnitTest.Issues.TestProtos {
} }
public ItemField() { } public ItemField() { }
public ItemField(ItemField other) { public ItemField(ItemField other) {
MergeFrom(other); item_ = other.item_;
}
public ItemField Clone() {
return new ItemField(this);
} }
public const int ItemFieldNumber = 1; public const int ItemFieldNumber = 1;
private int item_; private int item_;
public int Item { public int Item {
......
...@@ -402,7 +402,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -402,7 +402,7 @@ namespace Google.Protobuf.TestProtos {
#region Messages #region Messages
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestAllTypes : pb::IMessage<TestAllTypes>, global::System.IEquatable<TestAllTypes> { public sealed partial class TestAllTypes : pb::IMessage<TestAllTypes>, global::System.IEquatable<TestAllTypes>, pb::IDeepCloneable<TestAllTypes> {
private static readonly pb::MessageParser<TestAllTypes> _parser = new pb::MessageParser<TestAllTypes>(() => new TestAllTypes()); private static readonly pb::MessageParser<TestAllTypes> _parser = new pb::MessageParser<TestAllTypes>(() => new TestAllTypes());
public static pb::MessageParser<TestAllTypes> Parser { get { return _parser; } } public static pb::MessageParser<TestAllTypes> Parser { get { return _parser; } }
...@@ -417,9 +417,73 @@ namespace Google.Protobuf.TestProtos { ...@@ -417,9 +417,73 @@ namespace Google.Protobuf.TestProtos {
} }
public TestAllTypes() { } public TestAllTypes() { }
public TestAllTypes(TestAllTypes other) { public TestAllTypes(TestAllTypes other) {
MergeFrom(other); singleInt32_ = other.singleInt32_;
singleInt64_ = other.singleInt64_;
singleUint32_ = other.singleUint32_;
singleUint64_ = other.singleUint64_;
singleSint32_ = other.singleSint32_;
singleSint64_ = other.singleSint64_;
singleFixed32_ = other.singleFixed32_;
singleFixed64_ = other.singleFixed64_;
singleSfixed32_ = other.singleSfixed32_;
singleSfixed64_ = other.singleSfixed64_;
singleFloat_ = other.singleFloat_;
singleDouble_ = other.singleDouble_;
singleBool_ = other.singleBool_;
singleString_ = other.singleString_;
singleBytes_ = other.singleBytes_;
SingleNestedMessage = other.singleNestedMessage_ != null ? other.SingleNestedMessage.Clone() : null;
SingleForeignMessage = other.singleForeignMessage_ != null ? other.SingleForeignMessage.Clone() : null;
SingleImportMessage = other.singleImportMessage_ != null ? other.SingleImportMessage.Clone() : null;
singleNestedEnum_ = other.singleNestedEnum_;
singleForeignEnum_ = other.singleForeignEnum_;
singleImportEnum_ = other.singleImportEnum_;
SinglePublicImportMessage = other.singlePublicImportMessage_ != null ? other.SinglePublicImportMessage.Clone() : null;
repeatedInt32_ = other.repeatedInt32_.Clone();
repeatedInt64_ = other.repeatedInt64_.Clone();
repeatedUint32_ = other.repeatedUint32_.Clone();
repeatedUint64_ = other.repeatedUint64_.Clone();
repeatedSint32_ = other.repeatedSint32_.Clone();
repeatedSint64_ = other.repeatedSint64_.Clone();
repeatedFixed32_ = other.repeatedFixed32_.Clone();
repeatedFixed64_ = other.repeatedFixed64_.Clone();
repeatedSfixed32_ = other.repeatedSfixed32_.Clone();
repeatedSfixed64_ = other.repeatedSfixed64_.Clone();
repeatedFloat_ = other.repeatedFloat_.Clone();
repeatedDouble_ = other.repeatedDouble_.Clone();
repeatedBool_ = other.repeatedBool_.Clone();
repeatedString_ = other.repeatedString_.Clone();
repeatedBytes_ = other.repeatedBytes_.Clone();
repeatedNestedMessage_ = other.repeatedNestedMessage_.Clone();
repeatedForeignMessage_ = other.repeatedForeignMessage_.Clone();
repeatedImportMessage_ = other.repeatedImportMessage_.Clone();
repeatedNestedEnum_ = other.repeatedNestedEnum_.Clone();
repeatedForeignEnum_ = other.repeatedForeignEnum_.Clone();
repeatedImportEnum_ = other.repeatedImportEnum_.Clone();
repeatedPublicImportMessage_ = other.repeatedPublicImportMessage_.Clone();
switch (other.OneofFieldCase) {
case OneofFieldOneofCase.OneofUint32:
OneofUint32 = other.OneofUint32;
break;
case OneofFieldOneofCase.OneofNestedMessage:
OneofNestedMessage = other.OneofNestedMessage.Clone();
break;
case OneofFieldOneofCase.OneofString:
OneofString = other.OneofString;
break;
case OneofFieldOneofCase.OneofBytes:
OneofBytes = other.OneofBytes;
break;
}
}
public TestAllTypes Clone() {
return new TestAllTypes(this);
} }
public const int SingleInt32FieldNumber = 1; public const int SingleInt32FieldNumber = 1;
private int singleInt32_; private int singleInt32_;
public int SingleInt32 { public int SingleInt32 {
...@@ -1686,7 +1750,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -1686,7 +1750,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class NestedMessage : pb::IMessage<NestedMessage>, global::System.IEquatable<NestedMessage> { public sealed partial class NestedMessage : pb::IMessage<NestedMessage>, global::System.IEquatable<NestedMessage>, pb::IDeepCloneable<NestedMessage> {
private static readonly pb::MessageParser<NestedMessage> _parser = new pb::MessageParser<NestedMessage>(() => new NestedMessage()); private static readonly pb::MessageParser<NestedMessage> _parser = new pb::MessageParser<NestedMessage>(() => new NestedMessage());
public static pb::MessageParser<NestedMessage> Parser { get { return _parser; } } public static pb::MessageParser<NestedMessage> Parser { get { return _parser; } }
...@@ -1701,9 +1765,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -1701,9 +1765,15 @@ namespace Google.Protobuf.TestProtos {
} }
public NestedMessage() { } public NestedMessage() { }
public NestedMessage(NestedMessage other) { public NestedMessage(NestedMessage other) {
MergeFrom(other); bb_ = other.bb_;
}
public NestedMessage Clone() {
return new NestedMessage(this);
} }
public const int BbFieldNumber = 1; public const int BbFieldNumber = 1;
private int bb_; private int bb_;
public int Bb { public int Bb {
...@@ -1783,7 +1853,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -1783,7 +1853,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class NestedTestAllTypes : pb::IMessage<NestedTestAllTypes>, global::System.IEquatable<NestedTestAllTypes> { public sealed partial class NestedTestAllTypes : pb::IMessage<NestedTestAllTypes>, global::System.IEquatable<NestedTestAllTypes>, pb::IDeepCloneable<NestedTestAllTypes> {
private static readonly pb::MessageParser<NestedTestAllTypes> _parser = new pb::MessageParser<NestedTestAllTypes>(() => new NestedTestAllTypes()); private static readonly pb::MessageParser<NestedTestAllTypes> _parser = new pb::MessageParser<NestedTestAllTypes>(() => new NestedTestAllTypes());
public static pb::MessageParser<NestedTestAllTypes> Parser { get { return _parser; } } public static pb::MessageParser<NestedTestAllTypes> Parser { get { return _parser; } }
...@@ -1798,9 +1868,17 @@ namespace Google.Protobuf.TestProtos { ...@@ -1798,9 +1868,17 @@ namespace Google.Protobuf.TestProtos {
} }
public NestedTestAllTypes() { } public NestedTestAllTypes() { }
public NestedTestAllTypes(NestedTestAllTypes other) { public NestedTestAllTypes(NestedTestAllTypes other) {
MergeFrom(other); Child = other.child_ != null ? other.Child.Clone() : null;
Payload = other.payload_ != null ? other.Payload.Clone() : null;
repeatedChild_ = other.repeatedChild_.Clone();
} }
public NestedTestAllTypes Clone() {
return new NestedTestAllTypes(this);
}
public const int ChildFieldNumber = 1; public const int ChildFieldNumber = 1;
private global::Google.Protobuf.TestProtos.NestedTestAllTypes child_; private global::Google.Protobuf.TestProtos.NestedTestAllTypes child_;
public global::Google.Protobuf.TestProtos.NestedTestAllTypes Child { public global::Google.Protobuf.TestProtos.NestedTestAllTypes Child {
...@@ -1929,7 +2007,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -1929,7 +2007,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestDeprecatedFields : pb::IMessage<TestDeprecatedFields>, global::System.IEquatable<TestDeprecatedFields> { public sealed partial class TestDeprecatedFields : pb::IMessage<TestDeprecatedFields>, global::System.IEquatable<TestDeprecatedFields>, pb::IDeepCloneable<TestDeprecatedFields> {
private static readonly pb::MessageParser<TestDeprecatedFields> _parser = new pb::MessageParser<TestDeprecatedFields>(() => new TestDeprecatedFields()); private static readonly pb::MessageParser<TestDeprecatedFields> _parser = new pb::MessageParser<TestDeprecatedFields>(() => new TestDeprecatedFields());
public static pb::MessageParser<TestDeprecatedFields> Parser { get { return _parser; } } public static pb::MessageParser<TestDeprecatedFields> Parser { get { return _parser; } }
...@@ -1944,9 +2022,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -1944,9 +2022,15 @@ namespace Google.Protobuf.TestProtos {
} }
public TestDeprecatedFields() { } public TestDeprecatedFields() { }
public TestDeprecatedFields(TestDeprecatedFields other) { public TestDeprecatedFields(TestDeprecatedFields other) {
MergeFrom(other); deprecatedInt32_ = other.deprecatedInt32_;
}
public TestDeprecatedFields Clone() {
return new TestDeprecatedFields(this);
} }
public const int DeprecatedInt32FieldNumber = 1; public const int DeprecatedInt32FieldNumber = 1;
private int deprecatedInt32_; private int deprecatedInt32_;
[global::System.ObsoleteAttribute()] [global::System.ObsoleteAttribute()]
...@@ -2022,7 +2106,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2022,7 +2106,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class ForeignMessage : pb::IMessage<ForeignMessage>, global::System.IEquatable<ForeignMessage> { public sealed partial class ForeignMessage : pb::IMessage<ForeignMessage>, global::System.IEquatable<ForeignMessage>, pb::IDeepCloneable<ForeignMessage> {
private static readonly pb::MessageParser<ForeignMessage> _parser = new pb::MessageParser<ForeignMessage>(() => new ForeignMessage()); private static readonly pb::MessageParser<ForeignMessage> _parser = new pb::MessageParser<ForeignMessage>(() => new ForeignMessage());
public static pb::MessageParser<ForeignMessage> Parser { get { return _parser; } } public static pb::MessageParser<ForeignMessage> Parser { get { return _parser; } }
...@@ -2037,9 +2121,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -2037,9 +2121,15 @@ namespace Google.Protobuf.TestProtos {
} }
public ForeignMessage() { } public ForeignMessage() { }
public ForeignMessage(ForeignMessage other) { public ForeignMessage(ForeignMessage other) {
MergeFrom(other); c_ = other.c_;
} }
public ForeignMessage Clone() {
return new ForeignMessage(this);
}
public const int CFieldNumber = 1; public const int CFieldNumber = 1;
private int c_; private int c_;
public int C { public int C {
...@@ -2114,7 +2204,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2114,7 +2204,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestReservedFields : pb::IMessage<TestReservedFields>, global::System.IEquatable<TestReservedFields> { public sealed partial class TestReservedFields : pb::IMessage<TestReservedFields>, global::System.IEquatable<TestReservedFields>, pb::IDeepCloneable<TestReservedFields> {
private static readonly pb::MessageParser<TestReservedFields> _parser = new pb::MessageParser<TestReservedFields>(() => new TestReservedFields()); private static readonly pb::MessageParser<TestReservedFields> _parser = new pb::MessageParser<TestReservedFields>(() => new TestReservedFields());
public static pb::MessageParser<TestReservedFields> Parser { get { return _parser; } } public static pb::MessageParser<TestReservedFields> Parser { get { return _parser; } }
...@@ -2129,9 +2219,14 @@ namespace Google.Protobuf.TestProtos { ...@@ -2129,9 +2219,14 @@ namespace Google.Protobuf.TestProtos {
} }
public TestReservedFields() { } public TestReservedFields() { }
public TestReservedFields(TestReservedFields other) { public TestReservedFields(TestReservedFields other) {
MergeFrom(other);
} }
public TestReservedFields Clone() {
return new TestReservedFields(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as TestReservedFields); return Equals(other as TestReservedFields);
} }
...@@ -2182,7 +2277,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2182,7 +2277,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestForeignNested : pb::IMessage<TestForeignNested>, global::System.IEquatable<TestForeignNested> { public sealed partial class TestForeignNested : pb::IMessage<TestForeignNested>, global::System.IEquatable<TestForeignNested>, pb::IDeepCloneable<TestForeignNested> {
private static readonly pb::MessageParser<TestForeignNested> _parser = new pb::MessageParser<TestForeignNested>(() => new TestForeignNested()); private static readonly pb::MessageParser<TestForeignNested> _parser = new pb::MessageParser<TestForeignNested>(() => new TestForeignNested());
public static pb::MessageParser<TestForeignNested> Parser { get { return _parser; } } public static pb::MessageParser<TestForeignNested> Parser { get { return _parser; } }
...@@ -2197,9 +2292,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -2197,9 +2292,15 @@ namespace Google.Protobuf.TestProtos {
} }
public TestForeignNested() { } public TestForeignNested() { }
public TestForeignNested(TestForeignNested other) { public TestForeignNested(TestForeignNested other) {
MergeFrom(other); ForeignNested = other.foreignNested_ != null ? other.ForeignNested.Clone() : null;
}
public TestForeignNested Clone() {
return new TestForeignNested(this);
} }
public const int ForeignNestedFieldNumber = 1; public const int ForeignNestedFieldNumber = 1;
private global::Google.Protobuf.TestProtos.TestAllTypes.Types.NestedMessage foreignNested_; private global::Google.Protobuf.TestProtos.TestAllTypes.Types.NestedMessage foreignNested_;
public global::Google.Protobuf.TestProtos.TestAllTypes.Types.NestedMessage ForeignNested { public global::Google.Protobuf.TestProtos.TestAllTypes.Types.NestedMessage ForeignNested {
...@@ -2278,7 +2379,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2278,7 +2379,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestReallyLargeTagNumber : pb::IMessage<TestReallyLargeTagNumber>, global::System.IEquatable<TestReallyLargeTagNumber> { public sealed partial class TestReallyLargeTagNumber : pb::IMessage<TestReallyLargeTagNumber>, global::System.IEquatable<TestReallyLargeTagNumber>, pb::IDeepCloneable<TestReallyLargeTagNumber> {
private static readonly pb::MessageParser<TestReallyLargeTagNumber> _parser = new pb::MessageParser<TestReallyLargeTagNumber>(() => new TestReallyLargeTagNumber()); private static readonly pb::MessageParser<TestReallyLargeTagNumber> _parser = new pb::MessageParser<TestReallyLargeTagNumber>(() => new TestReallyLargeTagNumber());
public static pb::MessageParser<TestReallyLargeTagNumber> Parser { get { return _parser; } } public static pb::MessageParser<TestReallyLargeTagNumber> Parser { get { return _parser; } }
...@@ -2293,9 +2394,16 @@ namespace Google.Protobuf.TestProtos { ...@@ -2293,9 +2394,16 @@ namespace Google.Protobuf.TestProtos {
} }
public TestReallyLargeTagNumber() { } public TestReallyLargeTagNumber() { }
public TestReallyLargeTagNumber(TestReallyLargeTagNumber other) { public TestReallyLargeTagNumber(TestReallyLargeTagNumber other) {
MergeFrom(other); a_ = other.a_;
bb_ = other.bb_;
} }
public TestReallyLargeTagNumber Clone() {
return new TestReallyLargeTagNumber(this);
}
public const int AFieldNumber = 1; public const int AFieldNumber = 1;
private int a_; private int a_;
public int A { public int A {
...@@ -2394,7 +2502,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2394,7 +2502,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestRecursiveMessage : pb::IMessage<TestRecursiveMessage>, global::System.IEquatable<TestRecursiveMessage> { public sealed partial class TestRecursiveMessage : pb::IMessage<TestRecursiveMessage>, global::System.IEquatable<TestRecursiveMessage>, pb::IDeepCloneable<TestRecursiveMessage> {
private static readonly pb::MessageParser<TestRecursiveMessage> _parser = new pb::MessageParser<TestRecursiveMessage>(() => new TestRecursiveMessage()); private static readonly pb::MessageParser<TestRecursiveMessage> _parser = new pb::MessageParser<TestRecursiveMessage>(() => new TestRecursiveMessage());
public static pb::MessageParser<TestRecursiveMessage> Parser { get { return _parser; } } public static pb::MessageParser<TestRecursiveMessage> Parser { get { return _parser; } }
...@@ -2409,9 +2517,16 @@ namespace Google.Protobuf.TestProtos { ...@@ -2409,9 +2517,16 @@ namespace Google.Protobuf.TestProtos {
} }
public TestRecursiveMessage() { } public TestRecursiveMessage() { }
public TestRecursiveMessage(TestRecursiveMessage other) { public TestRecursiveMessage(TestRecursiveMessage other) {
MergeFrom(other); A = other.a_ != null ? other.A.Clone() : null;
i_ = other.i_;
}
public TestRecursiveMessage Clone() {
return new TestRecursiveMessage(this);
} }
public const int AFieldNumber = 1; public const int AFieldNumber = 1;
private global::Google.Protobuf.TestProtos.TestRecursiveMessage a_; private global::Google.Protobuf.TestProtos.TestRecursiveMessage a_;
public global::Google.Protobuf.TestProtos.TestRecursiveMessage A { public global::Google.Protobuf.TestProtos.TestRecursiveMessage A {
...@@ -2514,7 +2629,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2514,7 +2629,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestMutualRecursionA : pb::IMessage<TestMutualRecursionA>, global::System.IEquatable<TestMutualRecursionA> { public sealed partial class TestMutualRecursionA : pb::IMessage<TestMutualRecursionA>, global::System.IEquatable<TestMutualRecursionA>, pb::IDeepCloneable<TestMutualRecursionA> {
private static readonly pb::MessageParser<TestMutualRecursionA> _parser = new pb::MessageParser<TestMutualRecursionA>(() => new TestMutualRecursionA()); private static readonly pb::MessageParser<TestMutualRecursionA> _parser = new pb::MessageParser<TestMutualRecursionA>(() => new TestMutualRecursionA());
public static pb::MessageParser<TestMutualRecursionA> Parser { get { return _parser; } } public static pb::MessageParser<TestMutualRecursionA> Parser { get { return _parser; } }
...@@ -2529,9 +2644,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -2529,9 +2644,15 @@ namespace Google.Protobuf.TestProtos {
} }
public TestMutualRecursionA() { } public TestMutualRecursionA() { }
public TestMutualRecursionA(TestMutualRecursionA other) { public TestMutualRecursionA(TestMutualRecursionA other) {
MergeFrom(other); Bb = other.bb_ != null ? other.Bb.Clone() : null;
} }
public TestMutualRecursionA Clone() {
return new TestMutualRecursionA(this);
}
public const int BbFieldNumber = 1; public const int BbFieldNumber = 1;
private global::Google.Protobuf.TestProtos.TestMutualRecursionB bb_; private global::Google.Protobuf.TestProtos.TestMutualRecursionB bb_;
public global::Google.Protobuf.TestProtos.TestMutualRecursionB Bb { public global::Google.Protobuf.TestProtos.TestMutualRecursionB Bb {
...@@ -2610,7 +2731,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2610,7 +2731,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestMutualRecursionB : pb::IMessage<TestMutualRecursionB>, global::System.IEquatable<TestMutualRecursionB> { public sealed partial class TestMutualRecursionB : pb::IMessage<TestMutualRecursionB>, global::System.IEquatable<TestMutualRecursionB>, pb::IDeepCloneable<TestMutualRecursionB> {
private static readonly pb::MessageParser<TestMutualRecursionB> _parser = new pb::MessageParser<TestMutualRecursionB>(() => new TestMutualRecursionB()); private static readonly pb::MessageParser<TestMutualRecursionB> _parser = new pb::MessageParser<TestMutualRecursionB>(() => new TestMutualRecursionB());
public static pb::MessageParser<TestMutualRecursionB> Parser { get { return _parser; } } public static pb::MessageParser<TestMutualRecursionB> Parser { get { return _parser; } }
...@@ -2625,9 +2746,16 @@ namespace Google.Protobuf.TestProtos { ...@@ -2625,9 +2746,16 @@ namespace Google.Protobuf.TestProtos {
} }
public TestMutualRecursionB() { } public TestMutualRecursionB() { }
public TestMutualRecursionB(TestMutualRecursionB other) { public TestMutualRecursionB(TestMutualRecursionB other) {
MergeFrom(other); A = other.a_ != null ? other.A.Clone() : null;
optionalInt32_ = other.optionalInt32_;
}
public TestMutualRecursionB Clone() {
return new TestMutualRecursionB(this);
} }
public const int AFieldNumber = 1; public const int AFieldNumber = 1;
private global::Google.Protobuf.TestProtos.TestMutualRecursionA a_; private global::Google.Protobuf.TestProtos.TestMutualRecursionA a_;
public global::Google.Protobuf.TestProtos.TestMutualRecursionA A { public global::Google.Protobuf.TestProtos.TestMutualRecursionA A {
...@@ -2730,7 +2858,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2730,7 +2858,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestCamelCaseFieldNames : pb::IMessage<TestCamelCaseFieldNames>, global::System.IEquatable<TestCamelCaseFieldNames> { public sealed partial class TestCamelCaseFieldNames : pb::IMessage<TestCamelCaseFieldNames>, global::System.IEquatable<TestCamelCaseFieldNames>, pb::IDeepCloneable<TestCamelCaseFieldNames> {
private static readonly pb::MessageParser<TestCamelCaseFieldNames> _parser = new pb::MessageParser<TestCamelCaseFieldNames>(() => new TestCamelCaseFieldNames()); private static readonly pb::MessageParser<TestCamelCaseFieldNames> _parser = new pb::MessageParser<TestCamelCaseFieldNames>(() => new TestCamelCaseFieldNames());
public static pb::MessageParser<TestCamelCaseFieldNames> Parser { get { return _parser; } } public static pb::MessageParser<TestCamelCaseFieldNames> Parser { get { return _parser; } }
...@@ -2745,9 +2873,22 @@ namespace Google.Protobuf.TestProtos { ...@@ -2745,9 +2873,22 @@ namespace Google.Protobuf.TestProtos {
} }
public TestCamelCaseFieldNames() { } public TestCamelCaseFieldNames() { }
public TestCamelCaseFieldNames(TestCamelCaseFieldNames other) { public TestCamelCaseFieldNames(TestCamelCaseFieldNames other) {
MergeFrom(other); primitiveField_ = other.primitiveField_;
stringField_ = other.stringField_;
enumField_ = other.enumField_;
MessageField = other.messageField_ != null ? other.MessageField.Clone() : null;
repeatedPrimitiveField_ = other.repeatedPrimitiveField_.Clone();
repeatedStringField_ = other.repeatedStringField_.Clone();
repeatedEnumField_ = other.repeatedEnumField_.Clone();
repeatedMessageField_ = other.repeatedMessageField_.Clone();
}
public TestCamelCaseFieldNames Clone() {
return new TestCamelCaseFieldNames(this);
} }
public const int PrimitiveFieldFieldNumber = 1; public const int PrimitiveFieldFieldNumber = 1;
private int primitiveField_; private int primitiveField_;
public int PrimitiveField { public int PrimitiveField {
...@@ -2996,7 +3137,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -2996,7 +3137,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestFieldOrderings : pb::IMessage<TestFieldOrderings>, global::System.IEquatable<TestFieldOrderings> { public sealed partial class TestFieldOrderings : pb::IMessage<TestFieldOrderings>, global::System.IEquatable<TestFieldOrderings>, pb::IDeepCloneable<TestFieldOrderings> {
private static readonly pb::MessageParser<TestFieldOrderings> _parser = new pb::MessageParser<TestFieldOrderings>(() => new TestFieldOrderings()); private static readonly pb::MessageParser<TestFieldOrderings> _parser = new pb::MessageParser<TestFieldOrderings>(() => new TestFieldOrderings());
public static pb::MessageParser<TestFieldOrderings> Parser { get { return _parser; } } public static pb::MessageParser<TestFieldOrderings> Parser { get { return _parser; } }
...@@ -3011,9 +3152,18 @@ namespace Google.Protobuf.TestProtos { ...@@ -3011,9 +3152,18 @@ namespace Google.Protobuf.TestProtos {
} }
public TestFieldOrderings() { } public TestFieldOrderings() { }
public TestFieldOrderings(TestFieldOrderings other) { public TestFieldOrderings(TestFieldOrderings other) {
MergeFrom(other); myString_ = other.myString_;
myInt_ = other.myInt_;
myFloat_ = other.myFloat_;
SingleNestedMessage = other.singleNestedMessage_ != null ? other.SingleNestedMessage.Clone() : null;
} }
public TestFieldOrderings Clone() {
return new TestFieldOrderings(this);
}
public const int MyStringFieldNumber = 11; public const int MyStringFieldNumber = 11;
private string myString_ = ""; private string myString_ = "";
public string MyString { public string MyString {
...@@ -3165,7 +3315,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3165,7 +3315,7 @@ namespace Google.Protobuf.TestProtos {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public static partial class Types { public static partial class Types {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class NestedMessage : pb::IMessage<NestedMessage>, global::System.IEquatable<NestedMessage> { public sealed partial class NestedMessage : pb::IMessage<NestedMessage>, global::System.IEquatable<NestedMessage>, pb::IDeepCloneable<NestedMessage> {
private static readonly pb::MessageParser<NestedMessage> _parser = new pb::MessageParser<NestedMessage>(() => new NestedMessage()); private static readonly pb::MessageParser<NestedMessage> _parser = new pb::MessageParser<NestedMessage>(() => new NestedMessage());
public static pb::MessageParser<NestedMessage> Parser { get { return _parser; } } public static pb::MessageParser<NestedMessage> Parser { get { return _parser; } }
...@@ -3180,9 +3330,16 @@ namespace Google.Protobuf.TestProtos { ...@@ -3180,9 +3330,16 @@ namespace Google.Protobuf.TestProtos {
} }
public NestedMessage() { } public NestedMessage() { }
public NestedMessage(NestedMessage other) { public NestedMessage(NestedMessage other) {
MergeFrom(other); oo_ = other.oo_;
bb_ = other.bb_;
}
public NestedMessage Clone() {
return new NestedMessage(this);
} }
public const int OoFieldNumber = 2; public const int OoFieldNumber = 2;
private long oo_; private long oo_;
public long Oo { public long Oo {
...@@ -3286,7 +3443,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3286,7 +3443,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class SparseEnumMessage : pb::IMessage<SparseEnumMessage>, global::System.IEquatable<SparseEnumMessage> { public sealed partial class SparseEnumMessage : pb::IMessage<SparseEnumMessage>, global::System.IEquatable<SparseEnumMessage>, pb::IDeepCloneable<SparseEnumMessage> {
private static readonly pb::MessageParser<SparseEnumMessage> _parser = new pb::MessageParser<SparseEnumMessage>(() => new SparseEnumMessage()); private static readonly pb::MessageParser<SparseEnumMessage> _parser = new pb::MessageParser<SparseEnumMessage>(() => new SparseEnumMessage());
public static pb::MessageParser<SparseEnumMessage> Parser { get { return _parser; } } public static pb::MessageParser<SparseEnumMessage> Parser { get { return _parser; } }
...@@ -3301,9 +3458,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3301,9 +3458,15 @@ namespace Google.Protobuf.TestProtos {
} }
public SparseEnumMessage() { } public SparseEnumMessage() { }
public SparseEnumMessage(SparseEnumMessage other) { public SparseEnumMessage(SparseEnumMessage other) {
MergeFrom(other); sparseEnum_ = other.sparseEnum_;
} }
public SparseEnumMessage Clone() {
return new SparseEnumMessage(this);
}
public const int SparseEnumFieldNumber = 1; public const int SparseEnumFieldNumber = 1;
private global::Google.Protobuf.TestProtos.TestSparseEnum sparseEnum_ = global::Google.Protobuf.TestProtos.TestSparseEnum.TEST_SPARSE_ENUM_UNSPECIFIED; private global::Google.Protobuf.TestProtos.TestSparseEnum sparseEnum_ = global::Google.Protobuf.TestProtos.TestSparseEnum.TEST_SPARSE_ENUM_UNSPECIFIED;
public global::Google.Protobuf.TestProtos.TestSparseEnum SparseEnum { public global::Google.Protobuf.TestProtos.TestSparseEnum SparseEnum {
...@@ -3378,7 +3541,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3378,7 +3541,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class OneString : pb::IMessage<OneString>, global::System.IEquatable<OneString> { public sealed partial class OneString : pb::IMessage<OneString>, global::System.IEquatable<OneString>, pb::IDeepCloneable<OneString> {
private static readonly pb::MessageParser<OneString> _parser = new pb::MessageParser<OneString>(() => new OneString()); private static readonly pb::MessageParser<OneString> _parser = new pb::MessageParser<OneString>(() => new OneString());
public static pb::MessageParser<OneString> Parser { get { return _parser; } } public static pb::MessageParser<OneString> Parser { get { return _parser; } }
...@@ -3393,9 +3556,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3393,9 +3556,15 @@ namespace Google.Protobuf.TestProtos {
} }
public OneString() { } public OneString() { }
public OneString(OneString other) { public OneString(OneString other) {
MergeFrom(other); data_ = other.data_;
}
public OneString Clone() {
return new OneString(this);
} }
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private string data_ = ""; private string data_ = "";
public string Data { public string Data {
...@@ -3470,7 +3639,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3470,7 +3639,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class MoreString : pb::IMessage<MoreString>, global::System.IEquatable<MoreString> { public sealed partial class MoreString : pb::IMessage<MoreString>, global::System.IEquatable<MoreString>, pb::IDeepCloneable<MoreString> {
private static readonly pb::MessageParser<MoreString> _parser = new pb::MessageParser<MoreString>(() => new MoreString()); private static readonly pb::MessageParser<MoreString> _parser = new pb::MessageParser<MoreString>(() => new MoreString());
public static pb::MessageParser<MoreString> Parser { get { return _parser; } } public static pb::MessageParser<MoreString> Parser { get { return _parser; } }
...@@ -3485,9 +3654,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3485,9 +3654,15 @@ namespace Google.Protobuf.TestProtos {
} }
public MoreString() { } public MoreString() { }
public MoreString(MoreString other) { public MoreString(MoreString other) {
MergeFrom(other); data_ = other.data_.Clone();
}
public MoreString Clone() {
return new MoreString(this);
} }
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private readonly pbc::RepeatedField<string> data_ = new pbc::RepeatedField<string>(); private readonly pbc::RepeatedField<string> data_ = new pbc::RepeatedField<string>();
public pbc::RepeatedField<string> Data { public pbc::RepeatedField<string> Data {
...@@ -3562,7 +3737,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3562,7 +3737,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class OneBytes : pb::IMessage<OneBytes>, global::System.IEquatable<OneBytes> { public sealed partial class OneBytes : pb::IMessage<OneBytes>, global::System.IEquatable<OneBytes>, pb::IDeepCloneable<OneBytes> {
private static readonly pb::MessageParser<OneBytes> _parser = new pb::MessageParser<OneBytes>(() => new OneBytes()); private static readonly pb::MessageParser<OneBytes> _parser = new pb::MessageParser<OneBytes>(() => new OneBytes());
public static pb::MessageParser<OneBytes> Parser { get { return _parser; } } public static pb::MessageParser<OneBytes> Parser { get { return _parser; } }
...@@ -3577,9 +3752,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3577,9 +3752,15 @@ namespace Google.Protobuf.TestProtos {
} }
public OneBytes() { } public OneBytes() { }
public OneBytes(OneBytes other) { public OneBytes(OneBytes other) {
MergeFrom(other); data_ = other.data_;
} }
public OneBytes Clone() {
return new OneBytes(this);
}
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private pb::ByteString data_ = pb::ByteString.Empty; private pb::ByteString data_ = pb::ByteString.Empty;
public pb::ByteString Data { public pb::ByteString Data {
...@@ -3654,7 +3835,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3654,7 +3835,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class MoreBytes : pb::IMessage<MoreBytes>, global::System.IEquatable<MoreBytes> { public sealed partial class MoreBytes : pb::IMessage<MoreBytes>, global::System.IEquatable<MoreBytes>, pb::IDeepCloneable<MoreBytes> {
private static readonly pb::MessageParser<MoreBytes> _parser = new pb::MessageParser<MoreBytes>(() => new MoreBytes()); private static readonly pb::MessageParser<MoreBytes> _parser = new pb::MessageParser<MoreBytes>(() => new MoreBytes());
public static pb::MessageParser<MoreBytes> Parser { get { return _parser; } } public static pb::MessageParser<MoreBytes> Parser { get { return _parser; } }
...@@ -3669,9 +3850,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3669,9 +3850,15 @@ namespace Google.Protobuf.TestProtos {
} }
public MoreBytes() { } public MoreBytes() { }
public MoreBytes(MoreBytes other) { public MoreBytes(MoreBytes other) {
MergeFrom(other); data_ = other.data_;
}
public MoreBytes Clone() {
return new MoreBytes(this);
} }
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private pb::ByteString data_ = pb::ByteString.Empty; private pb::ByteString data_ = pb::ByteString.Empty;
public pb::ByteString Data { public pb::ByteString Data {
...@@ -3746,7 +3933,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3746,7 +3933,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class Int32Message : pb::IMessage<Int32Message>, global::System.IEquatable<Int32Message> { public sealed partial class Int32Message : pb::IMessage<Int32Message>, global::System.IEquatable<Int32Message>, pb::IDeepCloneable<Int32Message> {
private static readonly pb::MessageParser<Int32Message> _parser = new pb::MessageParser<Int32Message>(() => new Int32Message()); private static readonly pb::MessageParser<Int32Message> _parser = new pb::MessageParser<Int32Message>(() => new Int32Message());
public static pb::MessageParser<Int32Message> Parser { get { return _parser; } } public static pb::MessageParser<Int32Message> Parser { get { return _parser; } }
...@@ -3761,9 +3948,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3761,9 +3948,15 @@ namespace Google.Protobuf.TestProtos {
} }
public Int32Message() { } public Int32Message() { }
public Int32Message(Int32Message other) { public Int32Message(Int32Message other) {
MergeFrom(other); data_ = other.data_;
} }
public Int32Message Clone() {
return new Int32Message(this);
}
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private int data_; private int data_;
public int Data { public int Data {
...@@ -3838,7 +4031,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3838,7 +4031,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class Uint32Message : pb::IMessage<Uint32Message>, global::System.IEquatable<Uint32Message> { public sealed partial class Uint32Message : pb::IMessage<Uint32Message>, global::System.IEquatable<Uint32Message>, pb::IDeepCloneable<Uint32Message> {
private static readonly pb::MessageParser<Uint32Message> _parser = new pb::MessageParser<Uint32Message>(() => new Uint32Message()); private static readonly pb::MessageParser<Uint32Message> _parser = new pb::MessageParser<Uint32Message>(() => new Uint32Message());
public static pb::MessageParser<Uint32Message> Parser { get { return _parser; } } public static pb::MessageParser<Uint32Message> Parser { get { return _parser; } }
...@@ -3853,9 +4046,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3853,9 +4046,15 @@ namespace Google.Protobuf.TestProtos {
} }
public Uint32Message() { } public Uint32Message() { }
public Uint32Message(Uint32Message other) { public Uint32Message(Uint32Message other) {
MergeFrom(other); data_ = other.data_;
}
public Uint32Message Clone() {
return new Uint32Message(this);
} }
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private uint data_; private uint data_;
public uint Data { public uint Data {
...@@ -3930,7 +4129,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -3930,7 +4129,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class Int64Message : pb::IMessage<Int64Message>, global::System.IEquatable<Int64Message> { public sealed partial class Int64Message : pb::IMessage<Int64Message>, global::System.IEquatable<Int64Message>, pb::IDeepCloneable<Int64Message> {
private static readonly pb::MessageParser<Int64Message> _parser = new pb::MessageParser<Int64Message>(() => new Int64Message()); private static readonly pb::MessageParser<Int64Message> _parser = new pb::MessageParser<Int64Message>(() => new Int64Message());
public static pb::MessageParser<Int64Message> Parser { get { return _parser; } } public static pb::MessageParser<Int64Message> Parser { get { return _parser; } }
...@@ -3945,9 +4144,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -3945,9 +4144,15 @@ namespace Google.Protobuf.TestProtos {
} }
public Int64Message() { } public Int64Message() { }
public Int64Message(Int64Message other) { public Int64Message(Int64Message other) {
MergeFrom(other); data_ = other.data_;
}
public Int64Message Clone() {
return new Int64Message(this);
} }
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private long data_; private long data_;
public long Data { public long Data {
...@@ -4022,7 +4227,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -4022,7 +4227,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class Uint64Message : pb::IMessage<Uint64Message>, global::System.IEquatable<Uint64Message> { public sealed partial class Uint64Message : pb::IMessage<Uint64Message>, global::System.IEquatable<Uint64Message>, pb::IDeepCloneable<Uint64Message> {
private static readonly pb::MessageParser<Uint64Message> _parser = new pb::MessageParser<Uint64Message>(() => new Uint64Message()); private static readonly pb::MessageParser<Uint64Message> _parser = new pb::MessageParser<Uint64Message>(() => new Uint64Message());
public static pb::MessageParser<Uint64Message> Parser { get { return _parser; } } public static pb::MessageParser<Uint64Message> Parser { get { return _parser; } }
...@@ -4037,9 +4242,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -4037,9 +4242,15 @@ namespace Google.Protobuf.TestProtos {
} }
public Uint64Message() { } public Uint64Message() { }
public Uint64Message(Uint64Message other) { public Uint64Message(Uint64Message other) {
MergeFrom(other); data_ = other.data_;
} }
public Uint64Message Clone() {
return new Uint64Message(this);
}
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private ulong data_; private ulong data_;
public ulong Data { public ulong Data {
...@@ -4114,7 +4325,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -4114,7 +4325,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class BoolMessage : pb::IMessage<BoolMessage>, global::System.IEquatable<BoolMessage> { public sealed partial class BoolMessage : pb::IMessage<BoolMessage>, global::System.IEquatable<BoolMessage>, pb::IDeepCloneable<BoolMessage> {
private static readonly pb::MessageParser<BoolMessage> _parser = new pb::MessageParser<BoolMessage>(() => new BoolMessage()); private static readonly pb::MessageParser<BoolMessage> _parser = new pb::MessageParser<BoolMessage>(() => new BoolMessage());
public static pb::MessageParser<BoolMessage> Parser { get { return _parser; } } public static pb::MessageParser<BoolMessage> Parser { get { return _parser; } }
...@@ -4129,9 +4340,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -4129,9 +4340,15 @@ namespace Google.Protobuf.TestProtos {
} }
public BoolMessage() { } public BoolMessage() { }
public BoolMessage(BoolMessage other) { public BoolMessage(BoolMessage other) {
MergeFrom(other); data_ = other.data_;
}
public BoolMessage Clone() {
return new BoolMessage(this);
} }
public const int DataFieldNumber = 1; public const int DataFieldNumber = 1;
private bool data_; private bool data_;
public bool Data { public bool Data {
...@@ -4206,7 +4423,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -4206,7 +4423,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestOneof : pb::IMessage<TestOneof>, global::System.IEquatable<TestOneof> { public sealed partial class TestOneof : pb::IMessage<TestOneof>, global::System.IEquatable<TestOneof>, pb::IDeepCloneable<TestOneof> {
private static readonly pb::MessageParser<TestOneof> _parser = new pb::MessageParser<TestOneof>(() => new TestOneof()); private static readonly pb::MessageParser<TestOneof> _parser = new pb::MessageParser<TestOneof>(() => new TestOneof());
public static pb::MessageParser<TestOneof> Parser { get { return _parser; } } public static pb::MessageParser<TestOneof> Parser { get { return _parser; } }
...@@ -4221,9 +4438,26 @@ namespace Google.Protobuf.TestProtos { ...@@ -4221,9 +4438,26 @@ namespace Google.Protobuf.TestProtos {
} }
public TestOneof() { } public TestOneof() { }
public TestOneof(TestOneof other) { public TestOneof(TestOneof other) {
MergeFrom(other); switch (other.FooCase) {
case FooOneofCase.FooInt:
FooInt = other.FooInt;
break;
case FooOneofCase.FooString:
FooString = other.FooString;
break;
case FooOneofCase.FooMessage:
FooMessage = other.FooMessage.Clone();
break;
}
}
public TestOneof Clone() {
return new TestOneof(this);
} }
public const int FooIntFieldNumber = 1; public const int FooIntFieldNumber = 1;
public int FooInt { public int FooInt {
get { return fooCase_ == FooOneofCase.FooInt ? (int) foo_ : 0; } get { return fooCase_ == FooOneofCase.FooInt ? (int) foo_ : 0; }
...@@ -4373,7 +4607,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -4373,7 +4607,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestPackedTypes : pb::IMessage<TestPackedTypes>, global::System.IEquatable<TestPackedTypes> { public sealed partial class TestPackedTypes : pb::IMessage<TestPackedTypes>, global::System.IEquatable<TestPackedTypes>, pb::IDeepCloneable<TestPackedTypes> {
private static readonly pb::MessageParser<TestPackedTypes> _parser = new pb::MessageParser<TestPackedTypes>(() => new TestPackedTypes()); private static readonly pb::MessageParser<TestPackedTypes> _parser = new pb::MessageParser<TestPackedTypes>(() => new TestPackedTypes());
public static pb::MessageParser<TestPackedTypes> Parser { get { return _parser; } } public static pb::MessageParser<TestPackedTypes> Parser { get { return _parser; } }
...@@ -4388,9 +4622,28 @@ namespace Google.Protobuf.TestProtos { ...@@ -4388,9 +4622,28 @@ namespace Google.Protobuf.TestProtos {
} }
public TestPackedTypes() { } public TestPackedTypes() { }
public TestPackedTypes(TestPackedTypes other) { public TestPackedTypes(TestPackedTypes other) {
MergeFrom(other); packedInt32_ = other.packedInt32_.Clone();
packedInt64_ = other.packedInt64_.Clone();
packedUint32_ = other.packedUint32_.Clone();
packedUint64_ = other.packedUint64_.Clone();
packedSint32_ = other.packedSint32_.Clone();
packedSint64_ = other.packedSint64_.Clone();
packedFixed32_ = other.packedFixed32_.Clone();
packedFixed64_ = other.packedFixed64_.Clone();
packedSfixed32_ = other.packedSfixed32_.Clone();
packedSfixed64_ = other.packedSfixed64_.Clone();
packedFloat_ = other.packedFloat_.Clone();
packedDouble_ = other.packedDouble_.Clone();
packedBool_ = other.packedBool_.Clone();
packedEnum_ = other.packedEnum_.Clone();
}
public TestPackedTypes Clone() {
return new TestPackedTypes(this);
} }
public const int PackedInt32FieldNumber = 90; public const int PackedInt32FieldNumber = 90;
private readonly pbc::RepeatedField<int> packedInt32_ = new pbc::RepeatedField<int>(); private readonly pbc::RepeatedField<int> packedInt32_ = new pbc::RepeatedField<int>();
public pbc::RepeatedField<int> PackedInt32 { public pbc::RepeatedField<int> PackedInt32 {
...@@ -4791,7 +5044,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -4791,7 +5044,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestUnpackedTypes : pb::IMessage<TestUnpackedTypes>, global::System.IEquatable<TestUnpackedTypes> { public sealed partial class TestUnpackedTypes : pb::IMessage<TestUnpackedTypes>, global::System.IEquatable<TestUnpackedTypes>, pb::IDeepCloneable<TestUnpackedTypes> {
private static readonly pb::MessageParser<TestUnpackedTypes> _parser = new pb::MessageParser<TestUnpackedTypes>(() => new TestUnpackedTypes()); private static readonly pb::MessageParser<TestUnpackedTypes> _parser = new pb::MessageParser<TestUnpackedTypes>(() => new TestUnpackedTypes());
public static pb::MessageParser<TestUnpackedTypes> Parser { get { return _parser; } } public static pb::MessageParser<TestUnpackedTypes> Parser { get { return _parser; } }
...@@ -4806,9 +5059,28 @@ namespace Google.Protobuf.TestProtos { ...@@ -4806,9 +5059,28 @@ namespace Google.Protobuf.TestProtos {
} }
public TestUnpackedTypes() { } public TestUnpackedTypes() { }
public TestUnpackedTypes(TestUnpackedTypes other) { public TestUnpackedTypes(TestUnpackedTypes other) {
MergeFrom(other); unpackedInt32_ = other.unpackedInt32_.Clone();
unpackedInt64_ = other.unpackedInt64_.Clone();
unpackedUint32_ = other.unpackedUint32_.Clone();
unpackedUint64_ = other.unpackedUint64_.Clone();
unpackedSint32_ = other.unpackedSint32_.Clone();
unpackedSint64_ = other.unpackedSint64_.Clone();
unpackedFixed32_ = other.unpackedFixed32_.Clone();
unpackedFixed64_ = other.unpackedFixed64_.Clone();
unpackedSfixed32_ = other.unpackedSfixed32_.Clone();
unpackedSfixed64_ = other.unpackedSfixed64_.Clone();
unpackedFloat_ = other.unpackedFloat_.Clone();
unpackedDouble_ = other.unpackedDouble_.Clone();
unpackedBool_ = other.unpackedBool_.Clone();
unpackedEnum_ = other.unpackedEnum_.Clone();
}
public TestUnpackedTypes Clone() {
return new TestUnpackedTypes(this);
} }
public const int UnpackedInt32FieldNumber = 90; public const int UnpackedInt32FieldNumber = 90;
private readonly pbc::RepeatedField<int> unpackedInt32_ = new pbc::RepeatedField<int>(); private readonly pbc::RepeatedField<int> unpackedInt32_ = new pbc::RepeatedField<int>();
public pbc::RepeatedField<int> UnpackedInt32 { public pbc::RepeatedField<int> UnpackedInt32 {
...@@ -5195,7 +5467,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5195,7 +5467,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestRepeatedScalarDifferentTagSizes : pb::IMessage<TestRepeatedScalarDifferentTagSizes>, global::System.IEquatable<TestRepeatedScalarDifferentTagSizes> { public sealed partial class TestRepeatedScalarDifferentTagSizes : pb::IMessage<TestRepeatedScalarDifferentTagSizes>, global::System.IEquatable<TestRepeatedScalarDifferentTagSizes>, pb::IDeepCloneable<TestRepeatedScalarDifferentTagSizes> {
private static readonly pb::MessageParser<TestRepeatedScalarDifferentTagSizes> _parser = new pb::MessageParser<TestRepeatedScalarDifferentTagSizes>(() => new TestRepeatedScalarDifferentTagSizes()); private static readonly pb::MessageParser<TestRepeatedScalarDifferentTagSizes> _parser = new pb::MessageParser<TestRepeatedScalarDifferentTagSizes>(() => new TestRepeatedScalarDifferentTagSizes());
public static pb::MessageParser<TestRepeatedScalarDifferentTagSizes> Parser { get { return _parser; } } public static pb::MessageParser<TestRepeatedScalarDifferentTagSizes> Parser { get { return _parser; } }
...@@ -5210,9 +5482,20 @@ namespace Google.Protobuf.TestProtos { ...@@ -5210,9 +5482,20 @@ namespace Google.Protobuf.TestProtos {
} }
public TestRepeatedScalarDifferentTagSizes() { } public TestRepeatedScalarDifferentTagSizes() { }
public TestRepeatedScalarDifferentTagSizes(TestRepeatedScalarDifferentTagSizes other) { public TestRepeatedScalarDifferentTagSizes(TestRepeatedScalarDifferentTagSizes other) {
MergeFrom(other); repeatedFixed32_ = other.repeatedFixed32_.Clone();
repeatedInt32_ = other.repeatedInt32_.Clone();
repeatedFixed64_ = other.repeatedFixed64_.Clone();
repeatedInt64_ = other.repeatedInt64_.Clone();
repeatedFloat_ = other.repeatedFloat_.Clone();
repeatedUint64_ = other.repeatedUint64_.Clone();
}
public TestRepeatedScalarDifferentTagSizes Clone() {
return new TestRepeatedScalarDifferentTagSizes(this);
} }
public const int RepeatedFixed32FieldNumber = 12; public const int RepeatedFixed32FieldNumber = 12;
private readonly pbc::RepeatedField<uint> repeatedFixed32_ = new pbc::RepeatedField<uint>(); private readonly pbc::RepeatedField<uint> repeatedFixed32_ = new pbc::RepeatedField<uint>();
public pbc::RepeatedField<uint> RepeatedFixed32 { public pbc::RepeatedField<uint> RepeatedFixed32 {
...@@ -5413,7 +5696,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5413,7 +5696,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class TestCommentInjectionMessage : pb::IMessage<TestCommentInjectionMessage>, global::System.IEquatable<TestCommentInjectionMessage> { public sealed partial class TestCommentInjectionMessage : pb::IMessage<TestCommentInjectionMessage>, global::System.IEquatable<TestCommentInjectionMessage>, pb::IDeepCloneable<TestCommentInjectionMessage> {
private static readonly pb::MessageParser<TestCommentInjectionMessage> _parser = new pb::MessageParser<TestCommentInjectionMessage>(() => new TestCommentInjectionMessage()); private static readonly pb::MessageParser<TestCommentInjectionMessage> _parser = new pb::MessageParser<TestCommentInjectionMessage>(() => new TestCommentInjectionMessage());
public static pb::MessageParser<TestCommentInjectionMessage> Parser { get { return _parser; } } public static pb::MessageParser<TestCommentInjectionMessage> Parser { get { return _parser; } }
...@@ -5428,9 +5711,15 @@ namespace Google.Protobuf.TestProtos { ...@@ -5428,9 +5711,15 @@ namespace Google.Protobuf.TestProtos {
} }
public TestCommentInjectionMessage() { } public TestCommentInjectionMessage() { }
public TestCommentInjectionMessage(TestCommentInjectionMessage other) { public TestCommentInjectionMessage(TestCommentInjectionMessage other) {
MergeFrom(other); a_ = other.a_;
}
public TestCommentInjectionMessage Clone() {
return new TestCommentInjectionMessage(this);
} }
public const int AFieldNumber = 1; public const int AFieldNumber = 1;
private string a_ = ""; private string a_ = "";
public string A { public string A {
...@@ -5505,7 +5794,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5505,7 +5794,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FooRequest : pb::IMessage<FooRequest>, global::System.IEquatable<FooRequest> { public sealed partial class FooRequest : pb::IMessage<FooRequest>, global::System.IEquatable<FooRequest>, pb::IDeepCloneable<FooRequest> {
private static readonly pb::MessageParser<FooRequest> _parser = new pb::MessageParser<FooRequest>(() => new FooRequest()); private static readonly pb::MessageParser<FooRequest> _parser = new pb::MessageParser<FooRequest>(() => new FooRequest());
public static pb::MessageParser<FooRequest> Parser { get { return _parser; } } public static pb::MessageParser<FooRequest> Parser { get { return _parser; } }
...@@ -5520,9 +5809,14 @@ namespace Google.Protobuf.TestProtos { ...@@ -5520,9 +5809,14 @@ namespace Google.Protobuf.TestProtos {
} }
public FooRequest() { } public FooRequest() { }
public FooRequest(FooRequest other) { public FooRequest(FooRequest other) {
MergeFrom(other);
} }
public FooRequest Clone() {
return new FooRequest(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as FooRequest); return Equals(other as FooRequest);
} }
...@@ -5573,7 +5867,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5573,7 +5867,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FooResponse : pb::IMessage<FooResponse>, global::System.IEquatable<FooResponse> { public sealed partial class FooResponse : pb::IMessage<FooResponse>, global::System.IEquatable<FooResponse>, pb::IDeepCloneable<FooResponse> {
private static readonly pb::MessageParser<FooResponse> _parser = new pb::MessageParser<FooResponse>(() => new FooResponse()); private static readonly pb::MessageParser<FooResponse> _parser = new pb::MessageParser<FooResponse>(() => new FooResponse());
public static pb::MessageParser<FooResponse> Parser { get { return _parser; } } public static pb::MessageParser<FooResponse> Parser { get { return _parser; } }
...@@ -5588,9 +5882,14 @@ namespace Google.Protobuf.TestProtos { ...@@ -5588,9 +5882,14 @@ namespace Google.Protobuf.TestProtos {
} }
public FooResponse() { } public FooResponse() { }
public FooResponse(FooResponse other) { public FooResponse(FooResponse other) {
MergeFrom(other);
} }
public FooResponse Clone() {
return new FooResponse(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as FooResponse); return Equals(other as FooResponse);
} }
...@@ -5641,7 +5940,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5641,7 +5940,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FooClientMessage : pb::IMessage<FooClientMessage>, global::System.IEquatable<FooClientMessage> { public sealed partial class FooClientMessage : pb::IMessage<FooClientMessage>, global::System.IEquatable<FooClientMessage>, pb::IDeepCloneable<FooClientMessage> {
private static readonly pb::MessageParser<FooClientMessage> _parser = new pb::MessageParser<FooClientMessage>(() => new FooClientMessage()); private static readonly pb::MessageParser<FooClientMessage> _parser = new pb::MessageParser<FooClientMessage>(() => new FooClientMessage());
public static pb::MessageParser<FooClientMessage> Parser { get { return _parser; } } public static pb::MessageParser<FooClientMessage> Parser { get { return _parser; } }
...@@ -5656,9 +5955,14 @@ namespace Google.Protobuf.TestProtos { ...@@ -5656,9 +5955,14 @@ namespace Google.Protobuf.TestProtos {
} }
public FooClientMessage() { } public FooClientMessage() { }
public FooClientMessage(FooClientMessage other) { public FooClientMessage(FooClientMessage other) {
MergeFrom(other);
} }
public FooClientMessage Clone() {
return new FooClientMessage(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as FooClientMessage); return Equals(other as FooClientMessage);
} }
...@@ -5709,7 +6013,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5709,7 +6013,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FooServerMessage : pb::IMessage<FooServerMessage>, global::System.IEquatable<FooServerMessage> { public sealed partial class FooServerMessage : pb::IMessage<FooServerMessage>, global::System.IEquatable<FooServerMessage>, pb::IDeepCloneable<FooServerMessage> {
private static readonly pb::MessageParser<FooServerMessage> _parser = new pb::MessageParser<FooServerMessage>(() => new FooServerMessage()); private static readonly pb::MessageParser<FooServerMessage> _parser = new pb::MessageParser<FooServerMessage>(() => new FooServerMessage());
public static pb::MessageParser<FooServerMessage> Parser { get { return _parser; } } public static pb::MessageParser<FooServerMessage> Parser { get { return _parser; } }
...@@ -5724,9 +6028,14 @@ namespace Google.Protobuf.TestProtos { ...@@ -5724,9 +6028,14 @@ namespace Google.Protobuf.TestProtos {
} }
public FooServerMessage() { } public FooServerMessage() { }
public FooServerMessage(FooServerMessage other) { public FooServerMessage(FooServerMessage other) {
MergeFrom(other);
} }
public FooServerMessage Clone() {
return new FooServerMessage(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as FooServerMessage); return Equals(other as FooServerMessage);
} }
...@@ -5777,7 +6086,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5777,7 +6086,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class BarRequest : pb::IMessage<BarRequest>, global::System.IEquatable<BarRequest> { public sealed partial class BarRequest : pb::IMessage<BarRequest>, global::System.IEquatable<BarRequest>, pb::IDeepCloneable<BarRequest> {
private static readonly pb::MessageParser<BarRequest> _parser = new pb::MessageParser<BarRequest>(() => new BarRequest()); private static readonly pb::MessageParser<BarRequest> _parser = new pb::MessageParser<BarRequest>(() => new BarRequest());
public static pb::MessageParser<BarRequest> Parser { get { return _parser; } } public static pb::MessageParser<BarRequest> Parser { get { return _parser; } }
...@@ -5792,9 +6101,14 @@ namespace Google.Protobuf.TestProtos { ...@@ -5792,9 +6101,14 @@ namespace Google.Protobuf.TestProtos {
} }
public BarRequest() { } public BarRequest() { }
public BarRequest(BarRequest other) { public BarRequest(BarRequest other) {
MergeFrom(other);
} }
public BarRequest Clone() {
return new BarRequest(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as BarRequest); return Equals(other as BarRequest);
} }
...@@ -5845,7 +6159,7 @@ namespace Google.Protobuf.TestProtos { ...@@ -5845,7 +6159,7 @@ namespace Google.Protobuf.TestProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class BarResponse : pb::IMessage<BarResponse>, global::System.IEquatable<BarResponse> { public sealed partial class BarResponse : pb::IMessage<BarResponse>, global::System.IEquatable<BarResponse>, pb::IDeepCloneable<BarResponse> {
private static readonly pb::MessageParser<BarResponse> _parser = new pb::MessageParser<BarResponse>(() => new BarResponse()); private static readonly pb::MessageParser<BarResponse> _parser = new pb::MessageParser<BarResponse>(() => new BarResponse());
public static pb::MessageParser<BarResponse> Parser { get { return _parser; } } public static pb::MessageParser<BarResponse> Parser { get { return _parser; } }
...@@ -5860,9 +6174,14 @@ namespace Google.Protobuf.TestProtos { ...@@ -5860,9 +6174,14 @@ namespace Google.Protobuf.TestProtos {
} }
public BarResponse() { } public BarResponse() { }
public BarResponse(BarResponse other) { public BarResponse(BarResponse other) {
MergeFrom(other);
} }
public BarResponse Clone() {
return new BarResponse(this);
}
public override bool Equals(object other) { public override bool Equals(object other) {
return Equals(other as BarResponse); return Equals(other as BarResponse);
} }
......
...@@ -139,7 +139,7 @@ namespace Google.Protobuf ...@@ -139,7 +139,7 @@ namespace Google.Protobuf
/// are copied, so further modifications to the array will not /// are copied, so further modifications to the array will not
/// be reflected in the returned ByteString. /// be reflected in the returned ByteString.
/// </summary> /// </summary>
public static ByteString CopyFrom(byte[] bytes) public static ByteString CopyFrom(params byte[] bytes)
{ {
return new ByteString((byte[]) bytes.Clone()); return new ByteString((byte[]) bytes.Clone());
} }
......
...@@ -12,6 +12,36 @@ namespace Google.Protobuf.Collections ...@@ -12,6 +12,36 @@ namespace Google.Protobuf.Collections
private T[] array = EmptyArray; private T[] array = EmptyArray;
private int count = 0; private int count = 0;
/// <summary>
/// Creates a deep clone of this repeated field.
/// </summary>
/// <remarks>
/// If the field type is
/// a message type, each element is also cloned; otherwise, it is
/// assumed that the field type is primitive (including string and
/// bytes, both of which are immutable) and so a simple copy is
/// equivalent to a deep clone.
/// </remarks>
/// <returns>A deep clone of this repeated field.</returns>
public RepeatedField<T> Clone()
{
RepeatedField<T> clone = new RepeatedField<T>();
if (array != EmptyArray)
{
clone.array = (T[])array.Clone();
IDeepCloneable<T>[] cloneableArray = clone.array as IDeepCloneable<T>[];
if (cloneableArray != null)
{
for (int i = 0; i < count; i++)
{
clone.array[i] = cloneableArray[i].Clone();
}
}
}
clone.count = count;
return clone;
}
private void EnsureSize(int size) private void EnsureSize(int size)
{ {
size = Math.Max(size, MinArraySize); size = Math.Max(size, MinArraySize);
......
...@@ -278,7 +278,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -278,7 +278,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
#region Messages #region Messages
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FileDescriptorSet : pb::IMessage<FileDescriptorSet>, global::System.IEquatable<FileDescriptorSet> { public sealed partial class FileDescriptorSet : pb::IMessage<FileDescriptorSet>, global::System.IEquatable<FileDescriptorSet>, pb::IDeepCloneable<FileDescriptorSet> {
private static readonly pb::MessageParser<FileDescriptorSet> _parser = new pb::MessageParser<FileDescriptorSet>(() => new FileDescriptorSet()); private static readonly pb::MessageParser<FileDescriptorSet> _parser = new pb::MessageParser<FileDescriptorSet>(() => new FileDescriptorSet());
public static pb::MessageParser<FileDescriptorSet> Parser { get { return _parser; } } public static pb::MessageParser<FileDescriptorSet> Parser { get { return _parser; } }
...@@ -293,9 +293,15 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -293,9 +293,15 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public FileDescriptorSet() { } public FileDescriptorSet() { }
public FileDescriptorSet(FileDescriptorSet other) { public FileDescriptorSet(FileDescriptorSet other) {
MergeFrom(other); file_ = other.file_.Clone();
}
public FileDescriptorSet Clone() {
return new FileDescriptorSet(this);
} }
public const int FileFieldNumber = 1; public const int FileFieldNumber = 1;
private readonly pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.FileDescriptorProto> file_ = new pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.FileDescriptorProto>(); private readonly pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.FileDescriptorProto> file_ = new pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.FileDescriptorProto>();
public pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.FileDescriptorProto> File { public pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.FileDescriptorProto> File {
...@@ -368,7 +374,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -368,7 +374,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FileDescriptorProto : pb::IMessage<FileDescriptorProto>, global::System.IEquatable<FileDescriptorProto> { public sealed partial class FileDescriptorProto : pb::IMessage<FileDescriptorProto>, global::System.IEquatable<FileDescriptorProto>, pb::IDeepCloneable<FileDescriptorProto> {
private static readonly pb::MessageParser<FileDescriptorProto> _parser = new pb::MessageParser<FileDescriptorProto>(() => new FileDescriptorProto()); private static readonly pb::MessageParser<FileDescriptorProto> _parser = new pb::MessageParser<FileDescriptorProto>(() => new FileDescriptorProto());
public static pb::MessageParser<FileDescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<FileDescriptorProto> Parser { get { return _parser; } }
...@@ -383,9 +389,26 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -383,9 +389,26 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public FileDescriptorProto() { } public FileDescriptorProto() { }
public FileDescriptorProto(FileDescriptorProto other) { public FileDescriptorProto(FileDescriptorProto other) {
MergeFrom(other); name_ = other.name_;
package_ = other.package_;
dependency_ = other.dependency_.Clone();
publicDependency_ = other.publicDependency_.Clone();
weakDependency_ = other.weakDependency_.Clone();
messageType_ = other.messageType_.Clone();
enumType_ = other.enumType_.Clone();
service_ = other.service_.Clone();
extension_ = other.extension_.Clone();
Options = other.options_ != null ? other.Options.Clone() : null;
SourceCodeInfo = other.sourceCodeInfo_ != null ? other.SourceCodeInfo.Clone() : null;
syntax_ = other.syntax_;
} }
public FileDescriptorProto Clone() {
return new FileDescriptorProto(this);
}
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -726,7 +749,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -726,7 +749,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class DescriptorProto : pb::IMessage<DescriptorProto>, global::System.IEquatable<DescriptorProto> { public sealed partial class DescriptorProto : pb::IMessage<DescriptorProto>, global::System.IEquatable<DescriptorProto>, pb::IDeepCloneable<DescriptorProto> {
private static readonly pb::MessageParser<DescriptorProto> _parser = new pb::MessageParser<DescriptorProto>(() => new DescriptorProto()); private static readonly pb::MessageParser<DescriptorProto> _parser = new pb::MessageParser<DescriptorProto>(() => new DescriptorProto());
public static pb::MessageParser<DescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<DescriptorProto> Parser { get { return _parser; } }
...@@ -741,9 +764,24 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -741,9 +764,24 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public DescriptorProto() { } public DescriptorProto() { }
public DescriptorProto(DescriptorProto other) { public DescriptorProto(DescriptorProto other) {
MergeFrom(other); name_ = other.name_;
field_ = other.field_.Clone();
extension_ = other.extension_.Clone();
nestedType_ = other.nestedType_.Clone();
enumType_ = other.enumType_.Clone();
extensionRange_ = other.extensionRange_.Clone();
oneofDecl_ = other.oneofDecl_.Clone();
Options = other.options_ != null ? other.Options.Clone() : null;
reservedRange_ = other.reservedRange_.Clone();
reservedName_ = other.reservedName_.Clone();
}
public DescriptorProto Clone() {
return new DescriptorProto(this);
} }
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -1025,7 +1063,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1025,7 +1063,7 @@ namespace Google.Protobuf.DescriptorProtos {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public static partial class Types { public static partial class Types {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class ExtensionRange : pb::IMessage<ExtensionRange>, global::System.IEquatable<ExtensionRange> { public sealed partial class ExtensionRange : pb::IMessage<ExtensionRange>, global::System.IEquatable<ExtensionRange>, pb::IDeepCloneable<ExtensionRange> {
private static readonly pb::MessageParser<ExtensionRange> _parser = new pb::MessageParser<ExtensionRange>(() => new ExtensionRange()); private static readonly pb::MessageParser<ExtensionRange> _parser = new pb::MessageParser<ExtensionRange>(() => new ExtensionRange());
public static pb::MessageParser<ExtensionRange> Parser { get { return _parser; } } public static pb::MessageParser<ExtensionRange> Parser { get { return _parser; } }
...@@ -1040,9 +1078,16 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1040,9 +1078,16 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public ExtensionRange() { } public ExtensionRange() { }
public ExtensionRange(ExtensionRange other) { public ExtensionRange(ExtensionRange other) {
MergeFrom(other); start_ = other.start_;
end_ = other.end_;
}
public ExtensionRange Clone() {
return new ExtensionRange(this);
} }
public const int StartFieldNumber = 1; public const int StartFieldNumber = 1;
private int start_; private int start_;
public int Start { public int Start {
...@@ -1141,7 +1186,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1141,7 +1186,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class ReservedRange : pb::IMessage<ReservedRange>, global::System.IEquatable<ReservedRange> { public sealed partial class ReservedRange : pb::IMessage<ReservedRange>, global::System.IEquatable<ReservedRange>, pb::IDeepCloneable<ReservedRange> {
private static readonly pb::MessageParser<ReservedRange> _parser = new pb::MessageParser<ReservedRange>(() => new ReservedRange()); private static readonly pb::MessageParser<ReservedRange> _parser = new pb::MessageParser<ReservedRange>(() => new ReservedRange());
public static pb::MessageParser<ReservedRange> Parser { get { return _parser; } } public static pb::MessageParser<ReservedRange> Parser { get { return _parser; } }
...@@ -1156,9 +1201,16 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1156,9 +1201,16 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public ReservedRange() { } public ReservedRange() { }
public ReservedRange(ReservedRange other) { public ReservedRange(ReservedRange other) {
MergeFrom(other); start_ = other.start_;
end_ = other.end_;
} }
public ReservedRange Clone() {
return new ReservedRange(this);
}
public const int StartFieldNumber = 1; public const int StartFieldNumber = 1;
private int start_; private int start_;
public int Start { public int Start {
...@@ -1262,7 +1314,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1262,7 +1314,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FieldDescriptorProto : pb::IMessage<FieldDescriptorProto>, global::System.IEquatable<FieldDescriptorProto> { public sealed partial class FieldDescriptorProto : pb::IMessage<FieldDescriptorProto>, global::System.IEquatable<FieldDescriptorProto>, pb::IDeepCloneable<FieldDescriptorProto> {
private static readonly pb::MessageParser<FieldDescriptorProto> _parser = new pb::MessageParser<FieldDescriptorProto>(() => new FieldDescriptorProto()); private static readonly pb::MessageParser<FieldDescriptorProto> _parser = new pb::MessageParser<FieldDescriptorProto>(() => new FieldDescriptorProto());
public static pb::MessageParser<FieldDescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<FieldDescriptorProto> Parser { get { return _parser; } }
...@@ -1277,9 +1329,23 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1277,9 +1329,23 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public FieldDescriptorProto() { } public FieldDescriptorProto() { }
public FieldDescriptorProto(FieldDescriptorProto other) { public FieldDescriptorProto(FieldDescriptorProto other) {
MergeFrom(other); name_ = other.name_;
number_ = other.number_;
label_ = other.label_;
type_ = other.type_;
typeName_ = other.typeName_;
extendee_ = other.extendee_;
defaultValue_ = other.defaultValue_;
oneofIndex_ = other.oneofIndex_;
Options = other.options_ != null ? other.Options.Clone() : null;
} }
public FieldDescriptorProto Clone() {
return new FieldDescriptorProto(this);
}
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -1583,7 +1649,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1583,7 +1649,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class OneofDescriptorProto : pb::IMessage<OneofDescriptorProto>, global::System.IEquatable<OneofDescriptorProto> { public sealed partial class OneofDescriptorProto : pb::IMessage<OneofDescriptorProto>, global::System.IEquatable<OneofDescriptorProto>, pb::IDeepCloneable<OneofDescriptorProto> {
private static readonly pb::MessageParser<OneofDescriptorProto> _parser = new pb::MessageParser<OneofDescriptorProto>(() => new OneofDescriptorProto()); private static readonly pb::MessageParser<OneofDescriptorProto> _parser = new pb::MessageParser<OneofDescriptorProto>(() => new OneofDescriptorProto());
public static pb::MessageParser<OneofDescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<OneofDescriptorProto> Parser { get { return _parser; } }
...@@ -1598,9 +1664,15 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1598,9 +1664,15 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public OneofDescriptorProto() { } public OneofDescriptorProto() { }
public OneofDescriptorProto(OneofDescriptorProto other) { public OneofDescriptorProto(OneofDescriptorProto other) {
MergeFrom(other); name_ = other.name_;
} }
public OneofDescriptorProto Clone() {
return new OneofDescriptorProto(this);
}
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -1675,7 +1747,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1675,7 +1747,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class EnumDescriptorProto : pb::IMessage<EnumDescriptorProto>, global::System.IEquatable<EnumDescriptorProto> { public sealed partial class EnumDescriptorProto : pb::IMessage<EnumDescriptorProto>, global::System.IEquatable<EnumDescriptorProto>, pb::IDeepCloneable<EnumDescriptorProto> {
private static readonly pb::MessageParser<EnumDescriptorProto> _parser = new pb::MessageParser<EnumDescriptorProto>(() => new EnumDescriptorProto()); private static readonly pb::MessageParser<EnumDescriptorProto> _parser = new pb::MessageParser<EnumDescriptorProto>(() => new EnumDescriptorProto());
public static pb::MessageParser<EnumDescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<EnumDescriptorProto> Parser { get { return _parser; } }
...@@ -1690,9 +1762,17 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1690,9 +1762,17 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public EnumDescriptorProto() { } public EnumDescriptorProto() { }
public EnumDescriptorProto(EnumDescriptorProto other) { public EnumDescriptorProto(EnumDescriptorProto other) {
MergeFrom(other); name_ = other.name_;
value_ = other.value_.Clone();
Options = other.options_ != null ? other.Options.Clone() : null;
}
public EnumDescriptorProto Clone() {
return new EnumDescriptorProto(this);
} }
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -1817,7 +1897,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1817,7 +1897,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class EnumValueDescriptorProto : pb::IMessage<EnumValueDescriptorProto>, global::System.IEquatable<EnumValueDescriptorProto> { public sealed partial class EnumValueDescriptorProto : pb::IMessage<EnumValueDescriptorProto>, global::System.IEquatable<EnumValueDescriptorProto>, pb::IDeepCloneable<EnumValueDescriptorProto> {
private static readonly pb::MessageParser<EnumValueDescriptorProto> _parser = new pb::MessageParser<EnumValueDescriptorProto>(() => new EnumValueDescriptorProto()); private static readonly pb::MessageParser<EnumValueDescriptorProto> _parser = new pb::MessageParser<EnumValueDescriptorProto>(() => new EnumValueDescriptorProto());
public static pb::MessageParser<EnumValueDescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<EnumValueDescriptorProto> Parser { get { return _parser; } }
...@@ -1832,9 +1912,17 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1832,9 +1912,17 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public EnumValueDescriptorProto() { } public EnumValueDescriptorProto() { }
public EnumValueDescriptorProto(EnumValueDescriptorProto other) { public EnumValueDescriptorProto(EnumValueDescriptorProto other) {
MergeFrom(other); name_ = other.name_;
number_ = other.number_;
Options = other.options_ != null ? other.Options.Clone() : null;
} }
public EnumValueDescriptorProto Clone() {
return new EnumValueDescriptorProto(this);
}
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -1961,7 +2049,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1961,7 +2049,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class ServiceDescriptorProto : pb::IMessage<ServiceDescriptorProto>, global::System.IEquatable<ServiceDescriptorProto> { public sealed partial class ServiceDescriptorProto : pb::IMessage<ServiceDescriptorProto>, global::System.IEquatable<ServiceDescriptorProto>, pb::IDeepCloneable<ServiceDescriptorProto> {
private static readonly pb::MessageParser<ServiceDescriptorProto> _parser = new pb::MessageParser<ServiceDescriptorProto>(() => new ServiceDescriptorProto()); private static readonly pb::MessageParser<ServiceDescriptorProto> _parser = new pb::MessageParser<ServiceDescriptorProto>(() => new ServiceDescriptorProto());
public static pb::MessageParser<ServiceDescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<ServiceDescriptorProto> Parser { get { return _parser; } }
...@@ -1976,9 +2064,17 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -1976,9 +2064,17 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public ServiceDescriptorProto() { } public ServiceDescriptorProto() { }
public ServiceDescriptorProto(ServiceDescriptorProto other) { public ServiceDescriptorProto(ServiceDescriptorProto other) {
MergeFrom(other); name_ = other.name_;
method_ = other.method_.Clone();
Options = other.options_ != null ? other.Options.Clone() : null;
}
public ServiceDescriptorProto Clone() {
return new ServiceDescriptorProto(this);
} }
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -2103,7 +2199,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2103,7 +2199,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class MethodDescriptorProto : pb::IMessage<MethodDescriptorProto>, global::System.IEquatable<MethodDescriptorProto> { public sealed partial class MethodDescriptorProto : pb::IMessage<MethodDescriptorProto>, global::System.IEquatable<MethodDescriptorProto>, pb::IDeepCloneable<MethodDescriptorProto> {
private static readonly pb::MessageParser<MethodDescriptorProto> _parser = new pb::MessageParser<MethodDescriptorProto>(() => new MethodDescriptorProto()); private static readonly pb::MessageParser<MethodDescriptorProto> _parser = new pb::MessageParser<MethodDescriptorProto>(() => new MethodDescriptorProto());
public static pb::MessageParser<MethodDescriptorProto> Parser { get { return _parser; } } public static pb::MessageParser<MethodDescriptorProto> Parser { get { return _parser; } }
...@@ -2118,9 +2214,20 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2118,9 +2214,20 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public MethodDescriptorProto() { } public MethodDescriptorProto() { }
public MethodDescriptorProto(MethodDescriptorProto other) { public MethodDescriptorProto(MethodDescriptorProto other) {
MergeFrom(other); name_ = other.name_;
inputType_ = other.inputType_;
outputType_ = other.outputType_;
Options = other.options_ != null ? other.Options.Clone() : null;
clientStreaming_ = other.clientStreaming_;
serverStreaming_ = other.serverStreaming_;
}
public MethodDescriptorProto Clone() {
return new MethodDescriptorProto(this);
} }
public const int NameFieldNumber = 1; public const int NameFieldNumber = 1;
private string name_ = ""; private string name_ = "";
public string Name { public string Name {
...@@ -2319,7 +2426,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2319,7 +2426,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FileOptions : pb::IMessage<FileOptions>, global::System.IEquatable<FileOptions> { public sealed partial class FileOptions : pb::IMessage<FileOptions>, global::System.IEquatable<FileOptions>, pb::IDeepCloneable<FileOptions> {
private static readonly pb::MessageParser<FileOptions> _parser = new pb::MessageParser<FileOptions>(() => new FileOptions()); private static readonly pb::MessageParser<FileOptions> _parser = new pb::MessageParser<FileOptions>(() => new FileOptions());
public static pb::MessageParser<FileOptions> Parser { get { return _parser; } } public static pb::MessageParser<FileOptions> Parser { get { return _parser; } }
...@@ -2334,9 +2441,29 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2334,9 +2441,29 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public FileOptions() { } public FileOptions() { }
public FileOptions(FileOptions other) { public FileOptions(FileOptions other) {
MergeFrom(other); javaPackage_ = other.javaPackage_;
javaOuterClassname_ = other.javaOuterClassname_;
javaMultipleFiles_ = other.javaMultipleFiles_;
javaGenerateEqualsAndHash_ = other.javaGenerateEqualsAndHash_;
javaStringCheckUtf8_ = other.javaStringCheckUtf8_;
optimizeFor_ = other.optimizeFor_;
goPackage_ = other.goPackage_;
ccGenericServices_ = other.ccGenericServices_;
javaGenericServices_ = other.javaGenericServices_;
pyGenericServices_ = other.pyGenericServices_;
deprecated_ = other.deprecated_;
ccEnableArenas_ = other.ccEnableArenas_;
objcClassPrefix_ = other.objcClassPrefix_;
csharpNamespace_ = other.csharpNamespace_;
uninterpretedOption_ = other.uninterpretedOption_.Clone();
}
public FileOptions Clone() {
return new FileOptions(this);
} }
public const int JavaPackageFieldNumber = 1; public const int JavaPackageFieldNumber = 1;
private string javaPackage_ = ""; private string javaPackage_ = "";
public string JavaPackage { public string JavaPackage {
...@@ -2757,7 +2884,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2757,7 +2884,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class MessageOptions : pb::IMessage<MessageOptions>, global::System.IEquatable<MessageOptions> { public sealed partial class MessageOptions : pb::IMessage<MessageOptions>, global::System.IEquatable<MessageOptions>, pb::IDeepCloneable<MessageOptions> {
private static readonly pb::MessageParser<MessageOptions> _parser = new pb::MessageParser<MessageOptions>(() => new MessageOptions()); private static readonly pb::MessageParser<MessageOptions> _parser = new pb::MessageParser<MessageOptions>(() => new MessageOptions());
public static pb::MessageParser<MessageOptions> Parser { get { return _parser; } } public static pb::MessageParser<MessageOptions> Parser { get { return _parser; } }
...@@ -2772,9 +2899,19 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2772,9 +2899,19 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public MessageOptions() { } public MessageOptions() { }
public MessageOptions(MessageOptions other) { public MessageOptions(MessageOptions other) {
MergeFrom(other); messageSetWireFormat_ = other.messageSetWireFormat_;
noStandardDescriptorAccessor_ = other.noStandardDescriptorAccessor_;
deprecated_ = other.deprecated_;
mapEntry_ = other.mapEntry_;
uninterpretedOption_ = other.uninterpretedOption_.Clone();
}
public MessageOptions Clone() {
return new MessageOptions(this);
} }
public const int MessageSetWireFormatFieldNumber = 1; public const int MessageSetWireFormatFieldNumber = 1;
private bool messageSetWireFormat_; private bool messageSetWireFormat_;
public bool MessageSetWireFormat { public bool MessageSetWireFormat {
...@@ -2943,7 +3080,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2943,7 +3080,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class FieldOptions : pb::IMessage<FieldOptions>, global::System.IEquatable<FieldOptions> { public sealed partial class FieldOptions : pb::IMessage<FieldOptions>, global::System.IEquatable<FieldOptions>, pb::IDeepCloneable<FieldOptions> {
private static readonly pb::MessageParser<FieldOptions> _parser = new pb::MessageParser<FieldOptions>(() => new FieldOptions()); private static readonly pb::MessageParser<FieldOptions> _parser = new pb::MessageParser<FieldOptions>(() => new FieldOptions());
public static pb::MessageParser<FieldOptions> Parser { get { return _parser; } } public static pb::MessageParser<FieldOptions> Parser { get { return _parser; } }
...@@ -2958,9 +3095,21 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -2958,9 +3095,21 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public FieldOptions() { } public FieldOptions() { }
public FieldOptions(FieldOptions other) { public FieldOptions(FieldOptions other) {
MergeFrom(other); ctype_ = other.ctype_;
packed_ = other.packed_;
jstype_ = other.jstype_;
lazy_ = other.lazy_;
deprecated_ = other.deprecated_;
weak_ = other.weak_;
uninterpretedOption_ = other.uninterpretedOption_.Clone();
} }
public FieldOptions Clone() {
return new FieldOptions(this);
}
public const int CtypeFieldNumber = 1; public const int CtypeFieldNumber = 1;
private global::Google.Protobuf.DescriptorProtos.FieldOptions.Types.CType ctype_ = global::Google.Protobuf.DescriptorProtos.FieldOptions.Types.CType.STRING; private global::Google.Protobuf.DescriptorProtos.FieldOptions.Types.CType ctype_ = global::Google.Protobuf.DescriptorProtos.FieldOptions.Types.CType.STRING;
public global::Google.Protobuf.DescriptorProtos.FieldOptions.Types.CType Ctype { public global::Google.Protobuf.DescriptorProtos.FieldOptions.Types.CType Ctype {
...@@ -3195,7 +3344,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3195,7 +3344,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class EnumOptions : pb::IMessage<EnumOptions>, global::System.IEquatable<EnumOptions> { public sealed partial class EnumOptions : pb::IMessage<EnumOptions>, global::System.IEquatable<EnumOptions>, pb::IDeepCloneable<EnumOptions> {
private static readonly pb::MessageParser<EnumOptions> _parser = new pb::MessageParser<EnumOptions>(() => new EnumOptions()); private static readonly pb::MessageParser<EnumOptions> _parser = new pb::MessageParser<EnumOptions>(() => new EnumOptions());
public static pb::MessageParser<EnumOptions> Parser { get { return _parser; } } public static pb::MessageParser<EnumOptions> Parser { get { return _parser; } }
...@@ -3210,9 +3359,17 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3210,9 +3359,17 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public EnumOptions() { } public EnumOptions() { }
public EnumOptions(EnumOptions other) { public EnumOptions(EnumOptions other) {
MergeFrom(other); allowAlias_ = other.allowAlias_;
deprecated_ = other.deprecated_;
uninterpretedOption_ = other.uninterpretedOption_.Clone();
}
public EnumOptions Clone() {
return new EnumOptions(this);
} }
public const int AllowAliasFieldNumber = 2; public const int AllowAliasFieldNumber = 2;
private bool allowAlias_; private bool allowAlias_;
public bool AllowAlias { public bool AllowAlias {
...@@ -3333,7 +3490,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3333,7 +3490,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class EnumValueOptions : pb::IMessage<EnumValueOptions>, global::System.IEquatable<EnumValueOptions> { public sealed partial class EnumValueOptions : pb::IMessage<EnumValueOptions>, global::System.IEquatable<EnumValueOptions>, pb::IDeepCloneable<EnumValueOptions> {
private static readonly pb::MessageParser<EnumValueOptions> _parser = new pb::MessageParser<EnumValueOptions>(() => new EnumValueOptions()); private static readonly pb::MessageParser<EnumValueOptions> _parser = new pb::MessageParser<EnumValueOptions>(() => new EnumValueOptions());
public static pb::MessageParser<EnumValueOptions> Parser { get { return _parser; } } public static pb::MessageParser<EnumValueOptions> Parser { get { return _parser; } }
...@@ -3348,9 +3505,16 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3348,9 +3505,16 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public EnumValueOptions() { } public EnumValueOptions() { }
public EnumValueOptions(EnumValueOptions other) { public EnumValueOptions(EnumValueOptions other) {
MergeFrom(other); deprecated_ = other.deprecated_;
uninterpretedOption_ = other.uninterpretedOption_.Clone();
} }
public EnumValueOptions Clone() {
return new EnumValueOptions(this);
}
public const int DeprecatedFieldNumber = 1; public const int DeprecatedFieldNumber = 1;
private bool deprecated_; private bool deprecated_;
public bool Deprecated { public bool Deprecated {
...@@ -3447,7 +3611,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3447,7 +3611,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class ServiceOptions : pb::IMessage<ServiceOptions>, global::System.IEquatable<ServiceOptions> { public sealed partial class ServiceOptions : pb::IMessage<ServiceOptions>, global::System.IEquatable<ServiceOptions>, pb::IDeepCloneable<ServiceOptions> {
private static readonly pb::MessageParser<ServiceOptions> _parser = new pb::MessageParser<ServiceOptions>(() => new ServiceOptions()); private static readonly pb::MessageParser<ServiceOptions> _parser = new pb::MessageParser<ServiceOptions>(() => new ServiceOptions());
public static pb::MessageParser<ServiceOptions> Parser { get { return _parser; } } public static pb::MessageParser<ServiceOptions> Parser { get { return _parser; } }
...@@ -3462,9 +3626,16 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3462,9 +3626,16 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public ServiceOptions() { } public ServiceOptions() { }
public ServiceOptions(ServiceOptions other) { public ServiceOptions(ServiceOptions other) {
MergeFrom(other); deprecated_ = other.deprecated_;
uninterpretedOption_ = other.uninterpretedOption_.Clone();
}
public ServiceOptions Clone() {
return new ServiceOptions(this);
} }
public const int DeprecatedFieldNumber = 33; public const int DeprecatedFieldNumber = 33;
private bool deprecated_; private bool deprecated_;
public bool Deprecated { public bool Deprecated {
...@@ -3561,7 +3732,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3561,7 +3732,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class MethodOptions : pb::IMessage<MethodOptions>, global::System.IEquatable<MethodOptions> { public sealed partial class MethodOptions : pb::IMessage<MethodOptions>, global::System.IEquatable<MethodOptions>, pb::IDeepCloneable<MethodOptions> {
private static readonly pb::MessageParser<MethodOptions> _parser = new pb::MessageParser<MethodOptions>(() => new MethodOptions()); private static readonly pb::MessageParser<MethodOptions> _parser = new pb::MessageParser<MethodOptions>(() => new MethodOptions());
public static pb::MessageParser<MethodOptions> Parser { get { return _parser; } } public static pb::MessageParser<MethodOptions> Parser { get { return _parser; } }
...@@ -3576,9 +3747,16 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3576,9 +3747,16 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public MethodOptions() { } public MethodOptions() { }
public MethodOptions(MethodOptions other) { public MethodOptions(MethodOptions other) {
MergeFrom(other); deprecated_ = other.deprecated_;
uninterpretedOption_ = other.uninterpretedOption_.Clone();
}
public MethodOptions Clone() {
return new MethodOptions(this);
} }
public const int DeprecatedFieldNumber = 33; public const int DeprecatedFieldNumber = 33;
private bool deprecated_; private bool deprecated_;
public bool Deprecated { public bool Deprecated {
...@@ -3675,7 +3853,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3675,7 +3853,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class UninterpretedOption : pb::IMessage<UninterpretedOption>, global::System.IEquatable<UninterpretedOption> { public sealed partial class UninterpretedOption : pb::IMessage<UninterpretedOption>, global::System.IEquatable<UninterpretedOption>, pb::IDeepCloneable<UninterpretedOption> {
private static readonly pb::MessageParser<UninterpretedOption> _parser = new pb::MessageParser<UninterpretedOption>(() => new UninterpretedOption()); private static readonly pb::MessageParser<UninterpretedOption> _parser = new pb::MessageParser<UninterpretedOption>(() => new UninterpretedOption());
public static pb::MessageParser<UninterpretedOption> Parser { get { return _parser; } } public static pb::MessageParser<UninterpretedOption> Parser { get { return _parser; } }
...@@ -3690,9 +3868,21 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3690,9 +3868,21 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public UninterpretedOption() { } public UninterpretedOption() { }
public UninterpretedOption(UninterpretedOption other) { public UninterpretedOption(UninterpretedOption other) {
MergeFrom(other); name_ = other.name_.Clone();
identifierValue_ = other.identifierValue_;
positiveIntValue_ = other.positiveIntValue_;
negativeIntValue_ = other.negativeIntValue_;
doubleValue_ = other.doubleValue_;
stringValue_ = other.stringValue_;
aggregateValue_ = other.aggregateValue_;
} }
public UninterpretedOption Clone() {
return new UninterpretedOption(this);
}
public const int NameFieldNumber = 2; public const int NameFieldNumber = 2;
private readonly pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.UninterpretedOption.Types.NamePart> name_ = new pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.UninterpretedOption.Types.NamePart>(); private readonly pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.UninterpretedOption.Types.NamePart> name_ = new pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.UninterpretedOption.Types.NamePart>();
public pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.UninterpretedOption.Types.NamePart> Name { public pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.UninterpretedOption.Types.NamePart> Name {
...@@ -3910,7 +4100,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3910,7 +4100,7 @@ namespace Google.Protobuf.DescriptorProtos {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public static partial class Types { public static partial class Types {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class NamePart : pb::IMessage<NamePart>, global::System.IEquatable<NamePart> { public sealed partial class NamePart : pb::IMessage<NamePart>, global::System.IEquatable<NamePart>, pb::IDeepCloneable<NamePart> {
private static readonly pb::MessageParser<NamePart> _parser = new pb::MessageParser<NamePart>(() => new NamePart()); private static readonly pb::MessageParser<NamePart> _parser = new pb::MessageParser<NamePart>(() => new NamePart());
public static pb::MessageParser<NamePart> Parser { get { return _parser; } } public static pb::MessageParser<NamePart> Parser { get { return _parser; } }
...@@ -3925,9 +4115,16 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -3925,9 +4115,16 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public NamePart() { } public NamePart() { }
public NamePart(NamePart other) { public NamePart(NamePart other) {
MergeFrom(other); namePart_ = other.namePart_;
isExtension_ = other.isExtension_;
} }
public NamePart Clone() {
return new NamePart(this);
}
public const int NamePart_FieldNumber = 1; public const int NamePart_FieldNumber = 1;
private string namePart_ = ""; private string namePart_ = "";
public string NamePart_ { public string NamePart_ {
...@@ -4031,7 +4228,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -4031,7 +4228,7 @@ namespace Google.Protobuf.DescriptorProtos {
} }
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class SourceCodeInfo : pb::IMessage<SourceCodeInfo>, global::System.IEquatable<SourceCodeInfo> { public sealed partial class SourceCodeInfo : pb::IMessage<SourceCodeInfo>, global::System.IEquatable<SourceCodeInfo>, pb::IDeepCloneable<SourceCodeInfo> {
private static readonly pb::MessageParser<SourceCodeInfo> _parser = new pb::MessageParser<SourceCodeInfo>(() => new SourceCodeInfo()); private static readonly pb::MessageParser<SourceCodeInfo> _parser = new pb::MessageParser<SourceCodeInfo>(() => new SourceCodeInfo());
public static pb::MessageParser<SourceCodeInfo> Parser { get { return _parser; } } public static pb::MessageParser<SourceCodeInfo> Parser { get { return _parser; } }
...@@ -4046,9 +4243,15 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -4046,9 +4243,15 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public SourceCodeInfo() { } public SourceCodeInfo() { }
public SourceCodeInfo(SourceCodeInfo other) { public SourceCodeInfo(SourceCodeInfo other) {
MergeFrom(other); location_ = other.location_.Clone();
}
public SourceCodeInfo Clone() {
return new SourceCodeInfo(this);
} }
public const int LocationFieldNumber = 1; public const int LocationFieldNumber = 1;
private readonly pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.SourceCodeInfo.Types.Location> location_ = new pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.SourceCodeInfo.Types.Location>(); private readonly pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.SourceCodeInfo.Types.Location> location_ = new pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.SourceCodeInfo.Types.Location>();
public pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.SourceCodeInfo.Types.Location> Location { public pbc::RepeatedField<global::Google.Protobuf.DescriptorProtos.SourceCodeInfo.Types.Location> Location {
...@@ -4122,7 +4325,7 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -4122,7 +4325,7 @@ namespace Google.Protobuf.DescriptorProtos {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public static partial class Types { public static partial class Types {
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()] [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
public sealed partial class Location : pb::IMessage<Location>, global::System.IEquatable<Location> { public sealed partial class Location : pb::IMessage<Location>, global::System.IEquatable<Location>, pb::IDeepCloneable<Location> {
private static readonly pb::MessageParser<Location> _parser = new pb::MessageParser<Location>(() => new Location()); private static readonly pb::MessageParser<Location> _parser = new pb::MessageParser<Location>(() => new Location());
public static pb::MessageParser<Location> Parser { get { return _parser; } } public static pb::MessageParser<Location> Parser { get { return _parser; } }
...@@ -4137,9 +4340,19 @@ namespace Google.Protobuf.DescriptorProtos { ...@@ -4137,9 +4340,19 @@ namespace Google.Protobuf.DescriptorProtos {
} }
public Location() { } public Location() { }
public Location(Location other) { public Location(Location other) {
MergeFrom(other); path_ = other.path_.Clone();
span_ = other.span_.Clone();
leadingComments_ = other.leadingComments_;
trailingComments_ = other.trailingComments_;
leadingDetachedComments_ = other.leadingDetachedComments_.Clone();
} }
public Location Clone() {
return new Location(this);
}
public const int PathFieldNumber = 1; public const int PathFieldNumber = 1;
private readonly pbc::RepeatedField<int> path_ = new pbc::RepeatedField<int>(); private readonly pbc::RepeatedField<int> path_ = new pbc::RepeatedField<int>();
public pbc::RepeatedField<int> Path { public pbc::RepeatedField<int> Path {
......
...@@ -93,4 +93,22 @@ namespace Google.Protobuf ...@@ -93,4 +93,22 @@ namespace Google.Protobuf
/// <param name="message">The message to merge with this one. Must not be null.</param> /// <param name="message">The message to merge with this one. Must not be null.</param>
void MergeFrom(T message); void MergeFrom(T message);
} }
/// <summary>
/// Generic interface for a deeply cloneable type.
/// <summary>
/// <remarks>
/// In practice, all generated messages implement this interface.
/// However, due to the type constraint on <c>T</c> in <see cref="IMessage{T}"/>,
/// it is simpler to keep this as a separate interface.
/// </remarks>
/// <typeparam name="T">The type itself, returned by the <see cref="Clone"/> method.</typeparam>
public interface IDeepCloneable<T>
{
/// <summary>
/// Creates a deep clone of this object.
/// </summary>
/// <returns>A deep clone of this object.</returns>
T Clone();
}
} }
\ No newline at end of file
...@@ -47,6 +47,7 @@ class FieldGeneratorBase : public SourceGeneratorBase { ...@@ -47,6 +47,7 @@ class FieldGeneratorBase : public SourceGeneratorBase {
FieldGeneratorBase(const FieldDescriptor* descriptor, int fieldOrdinal); FieldGeneratorBase(const FieldDescriptor* descriptor, int fieldOrdinal);
~FieldGeneratorBase(); ~FieldGeneratorBase();
virtual void GenerateCloningCode(io::Printer* printer) = 0;
virtual void GenerateMembers(io::Printer* printer) = 0; virtual void GenerateMembers(io::Printer* printer) = 0;
virtual void GenerateMergingCode(io::Printer* printer) = 0; virtual void GenerateMergingCode(io::Printer* printer) = 0;
virtual void GenerateParsingCode(io::Printer* printer) = 0; virtual void GenerateParsingCode(io::Printer* printer) = 0;
......
...@@ -179,7 +179,7 @@ void MessageGenerator::Generate(io::Printer* printer) { ...@@ -179,7 +179,7 @@ void MessageGenerator::Generate(io::Printer* printer) {
WriteGeneratedCodeAttributes(printer); WriteGeneratedCodeAttributes(printer);
printer->Print( printer->Print(
vars, vars,
"$access_level$ sealed partial class $class_name$ : pb::IMessage<$class_name$>, global::System.IEquatable<$class_name$> {\n"); "$access_level$ sealed partial class $class_name$ : pb::IMessage<$class_name$>, global::System.IEquatable<$class_name$>, pb::IDeepCloneable<$class_name$> {\n");
printer->Indent(); printer->Indent();
// All static fields and properties // All static fields and properties
...@@ -213,16 +213,12 @@ void MessageGenerator::Generate(io::Printer* printer) { ...@@ -213,16 +213,12 @@ void MessageGenerator::Generate(io::Printer* printer) {
"}\n" "}\n"
"\n"); "\n");
// Constructors // Parameterless constructor
printer->Print( printer->Print(
vars, vars,
"public $class_name$() { }\n"); // Public parameterless ctor. "public $class_name$() { }\n\n");
printer->Print( GenerateCloningCode(printer);
vars,
"public $class_name$($class_name$ other) {\n"
" MergeFrom(other);\n"
"}\n"); // Merge ctor.
// Fields/properties // Fields/properties
for (int i = 0; i < descriptor_->field_count(); i++) { for (int i = 0; i < descriptor_->field_count(); i++) {
...@@ -303,6 +299,53 @@ void MessageGenerator::Generate(io::Printer* printer) { ...@@ -303,6 +299,53 @@ void MessageGenerator::Generate(io::Printer* printer) {
} }
void MessageGenerator::GenerateCloningCode(io::Printer* printer) {
map<string, string> vars;
vars["class_name"] = class_name();
printer->Print(
vars,
"public $class_name$($class_name$ other) {\n");
printer->Indent();
// Clone non-oneof fields first
for (int i = 0; i < descriptor_->field_count(); i++) {
if (!descriptor_->field(i)->containing_oneof()) {
scoped_ptr<FieldGeneratorBase> generator(
CreateFieldGeneratorInternal(descriptor_->field(i)));
generator->GenerateCloningCode(printer);
}
}
// Clone just the right field for each oneof
for (int i = 0; i < descriptor_->oneof_decl_count(); ++i) {
vars["name"] = UnderscoresToCamelCase(descriptor_->oneof_decl(i)->name(), false);
vars["property_name"] = UnderscoresToCamelCase(descriptor_->oneof_decl(i)->name(), true);
printer->Print(vars, "switch (other.$property_name$Case) {\n");
printer->Indent();
for (int j = 0; j < descriptor_->oneof_decl(i)->field_count(); j++) {
const FieldDescriptor* field = descriptor_->oneof_decl(i)->field(j);
scoped_ptr<FieldGeneratorBase> generator(CreateFieldGeneratorInternal(field));
vars["field_property_name"] = GetPropertyName(field);
printer->Print(
vars,
"case $property_name$OneofCase.$field_property_name$:\n");
printer->Indent();
generator->GenerateCloningCode(printer);
printer->Print("break;\n");
printer->Outdent();
}
printer->Outdent();
printer->Print("}\n\n");
}
printer->Outdent();
printer->Print("}\n\n");
printer->Print(
vars,
"public $class_name$ Clone() {\n"
" return new $class_name$(this);\n"
"}\n\n");
}
void MessageGenerator::GenerateFrameworkMethods(io::Printer* printer) { void MessageGenerator::GenerateFrameworkMethods(io::Printer* printer) {
map<string, string> vars; map<string, string> vars;
vars["class_name"] = class_name(); vars["class_name"] = class_name();
......
...@@ -50,6 +50,7 @@ class MessageGenerator : public SourceGeneratorBase { ...@@ -50,6 +50,7 @@ class MessageGenerator : public SourceGeneratorBase {
MessageGenerator(const Descriptor* descriptor); MessageGenerator(const Descriptor* descriptor);
~MessageGenerator(); ~MessageGenerator();
void GenerateCloningCode(io::Printer* printer);
void GenerateFrameworkMethods(io::Printer* printer); void GenerateFrameworkMethods(io::Printer* printer);
void GenerateStaticVariables(io::Printer* printer); void GenerateStaticVariables(io::Printer* printer);
void GenerateStaticVariableInitializers(io::Printer* printer); void GenerateStaticVariableInitializers(io::Printer* printer);
......
...@@ -125,6 +125,11 @@ void MessageFieldGenerator::WriteToString(io::Printer* printer) { ...@@ -125,6 +125,11 @@ void MessageFieldGenerator::WriteToString(io::Printer* printer) {
"PrintField(\"$field_name$\", has$property_name$, $name$_, writer);\n"); "PrintField(\"$field_name$\", has$property_name$, $name$_, writer);\n");
} }
void MessageFieldGenerator::GenerateCloningCode(io::Printer* printer) {
printer->Print(variables_,
"$property_name$ = other.$has_property_check$ ? other.$property_name$.Clone() : null;\n");
}
MessageOneofFieldGenerator::MessageOneofFieldGenerator(const FieldDescriptor* descriptor, MessageOneofFieldGenerator::MessageOneofFieldGenerator(const FieldDescriptor* descriptor,
int fieldOrdinal) int fieldOrdinal)
: MessageFieldGenerator(descriptor, fieldOrdinal) { : MessageFieldGenerator(descriptor, fieldOrdinal) {
...@@ -166,6 +171,11 @@ void MessageOneofFieldGenerator::WriteToString(io::Printer* printer) { ...@@ -166,6 +171,11 @@ void MessageOneofFieldGenerator::WriteToString(io::Printer* printer) {
"PrintField(\"$descriptor_name$\", $has_property_check$, $oneof_name$_, writer);\n"); "PrintField(\"$descriptor_name$\", $has_property_check$, $oneof_name$_, writer);\n");
} }
void MessageOneofFieldGenerator::GenerateCloningCode(io::Printer* printer) {
printer->Print(variables_,
"$property_name$ = other.$property_name$.Clone();\n");
}
} // namespace csharp } // namespace csharp
} // namespace compiler } // namespace compiler
} // namespace protobuf } // namespace protobuf
......
...@@ -46,6 +46,7 @@ class MessageFieldGenerator : public FieldGeneratorBase { ...@@ -46,6 +46,7 @@ class MessageFieldGenerator : public FieldGeneratorBase {
MessageFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal); MessageFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal);
~MessageFieldGenerator(); ~MessageFieldGenerator();
virtual void GenerateCloningCode(io::Printer* printer);
virtual void GenerateMembers(io::Printer* printer); virtual void GenerateMembers(io::Printer* printer);
virtual void GenerateMergingCode(io::Printer* printer); virtual void GenerateMergingCode(io::Printer* printer);
virtual void GenerateParsingCode(io::Printer* printer); virtual void GenerateParsingCode(io::Printer* printer);
...@@ -65,6 +66,7 @@ class MessageOneofFieldGenerator : public MessageFieldGenerator { ...@@ -65,6 +66,7 @@ class MessageOneofFieldGenerator : public MessageFieldGenerator {
MessageOneofFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal); MessageOneofFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal);
~MessageOneofFieldGenerator(); ~MessageOneofFieldGenerator();
virtual void GenerateCloningCode(io::Printer* printer);
virtual void GenerateMembers(io::Printer* printer); virtual void GenerateMembers(io::Printer* printer);
virtual void WriteToString(io::Printer* printer); virtual void WriteToString(io::Printer* printer);
virtual void GenerateParsingCode(io::Printer* printer); virtual void GenerateParsingCode(io::Printer* printer);
......
...@@ -146,6 +146,11 @@ void PrimitiveFieldGenerator::WriteToString(io::Printer* printer) { ...@@ -146,6 +146,11 @@ void PrimitiveFieldGenerator::WriteToString(io::Printer* printer) {
"PrintField(\"$descriptor_name$\", $has_property_check$, $property_name$, writer);\n"); "PrintField(\"$descriptor_name$\", $has_property_check$, $property_name$, writer);\n");
} }
void PrimitiveFieldGenerator::GenerateCloningCode(io::Printer* printer) {
printer->Print(variables_,
"$name$_ = other.$name$_;\n");
}
PrimitiveOneofFieldGenerator::PrimitiveOneofFieldGenerator( PrimitiveOneofFieldGenerator::PrimitiveOneofFieldGenerator(
const FieldDescriptor* descriptor, int fieldOrdinal) const FieldDescriptor* descriptor, int fieldOrdinal)
: PrimitiveFieldGenerator(descriptor, fieldOrdinal) { : PrimitiveFieldGenerator(descriptor, fieldOrdinal) {
...@@ -189,6 +194,11 @@ void PrimitiveOneofFieldGenerator::GenerateParsingCode(io::Printer* printer) { ...@@ -189,6 +194,11 @@ void PrimitiveOneofFieldGenerator::GenerateParsingCode(io::Printer* printer) {
"$property_name$ = input.Read$capitalized_type_name$();\n"); "$property_name$ = input.Read$capitalized_type_name$();\n");
} }
void PrimitiveOneofFieldGenerator::GenerateCloningCode(io::Printer* printer) {
printer->Print(variables_,
"$property_name$ = other.$property_name$;\n");
}
} // namespace csharp } // namespace csharp
} // namespace compiler } // namespace compiler
} // namespace protobuf } // namespace protobuf
......
...@@ -46,6 +46,7 @@ class PrimitiveFieldGenerator : public FieldGeneratorBase { ...@@ -46,6 +46,7 @@ class PrimitiveFieldGenerator : public FieldGeneratorBase {
PrimitiveFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal); PrimitiveFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal);
~PrimitiveFieldGenerator(); ~PrimitiveFieldGenerator();
virtual void GenerateCloningCode(io::Printer* printer);
virtual void GenerateMembers(io::Printer* printer); virtual void GenerateMembers(io::Printer* printer);
virtual void GenerateMergingCode(io::Printer* printer); virtual void GenerateMergingCode(io::Printer* printer);
virtual void GenerateParsingCode(io::Printer* printer); virtual void GenerateParsingCode(io::Printer* printer);
...@@ -68,6 +69,7 @@ class PrimitiveOneofFieldGenerator : public PrimitiveFieldGenerator { ...@@ -68,6 +69,7 @@ class PrimitiveOneofFieldGenerator : public PrimitiveFieldGenerator {
PrimitiveOneofFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal); PrimitiveOneofFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal);
~PrimitiveOneofFieldGenerator(); ~PrimitiveOneofFieldGenerator();
virtual void GenerateCloningCode(io::Printer* printer);
virtual void GenerateMembers(io::Printer* printer); virtual void GenerateMembers(io::Printer* printer);
virtual void WriteToString(io::Printer* printer); virtual void WriteToString(io::Printer* printer);
virtual void GenerateParsingCode(io::Printer* printer); virtual void GenerateParsingCode(io::Printer* printer);
......
...@@ -142,6 +142,11 @@ void RepeatedEnumFieldGenerator::WriteToString(io::Printer* printer) { ...@@ -142,6 +142,11 @@ void RepeatedEnumFieldGenerator::WriteToString(io::Printer* printer) {
"PrintField(\"$descriptor_name$\", $name$_, writer);\n"); "PrintField(\"$descriptor_name$\", $name$_, writer);\n");
} }
void RepeatedEnumFieldGenerator::GenerateCloningCode(io::Printer* printer) {
printer->Print(variables_,
"$name$_ = other.$name$_.Clone();\n");
}
} // namespace csharp } // namespace csharp
} // namespace compiler } // namespace compiler
} // namespace protobuf } // namespace protobuf
......
...@@ -48,6 +48,7 @@ class RepeatedEnumFieldGenerator : public FieldGeneratorBase { ...@@ -48,6 +48,7 @@ class RepeatedEnumFieldGenerator : public FieldGeneratorBase {
RepeatedEnumFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal); RepeatedEnumFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal);
~RepeatedEnumFieldGenerator(); ~RepeatedEnumFieldGenerator();
virtual void GenerateCloningCode(io::Printer* printer);
virtual void GenerateMembers(io::Printer* printer); virtual void GenerateMembers(io::Printer* printer);
virtual void GenerateMergingCode(io::Printer* printer); virtual void GenerateMergingCode(io::Printer* printer);
virtual void GenerateParsingCode(io::Printer* printer); virtual void GenerateParsingCode(io::Printer* printer);
......
...@@ -118,6 +118,11 @@ void RepeatedMessageFieldGenerator::WriteToString(io::Printer* printer) { ...@@ -118,6 +118,11 @@ void RepeatedMessageFieldGenerator::WriteToString(io::Printer* printer) {
"PrintField(\"$field_name$\", $name$_, writer);\n"); "PrintField(\"$field_name$\", $name$_, writer);\n");
} }
void RepeatedMessageFieldGenerator::GenerateCloningCode(io::Printer* printer) {
printer->Print(variables_,
"$name$_ = other.$name$_.Clone();\n");
}
} // namespace csharp } // namespace csharp
} // namespace compiler } // namespace compiler
} // namespace protobuf } // namespace protobuf
......
...@@ -46,6 +46,7 @@ class RepeatedMessageFieldGenerator : public FieldGeneratorBase { ...@@ -46,6 +46,7 @@ class RepeatedMessageFieldGenerator : public FieldGeneratorBase {
RepeatedMessageFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal); RepeatedMessageFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal);
~RepeatedMessageFieldGenerator(); ~RepeatedMessageFieldGenerator();
virtual void GenerateCloningCode(io::Printer* printer);
virtual void GenerateMembers(io::Printer* printer); virtual void GenerateMembers(io::Printer* printer);
virtual void GenerateMergingCode(io::Printer* printer); virtual void GenerateMergingCode(io::Printer* printer);
virtual void GenerateParsingCode(io::Printer* printer); virtual void GenerateParsingCode(io::Printer* printer);
......
...@@ -148,6 +148,11 @@ void RepeatedPrimitiveFieldGenerator::WriteToString(io::Printer* printer) { ...@@ -148,6 +148,11 @@ void RepeatedPrimitiveFieldGenerator::WriteToString(io::Printer* printer) {
"PrintField(\"$descriptor_name$\", $name$_, writer);\n"); "PrintField(\"$descriptor_name$\", $name$_, writer);\n");
} }
void RepeatedPrimitiveFieldGenerator::GenerateCloningCode(io::Printer* printer) {
printer->Print(variables_,
"$name$_ = other.$name$_.Clone();\n");
}
} // namespace csharp } // namespace csharp
} // namespace compiler } // namespace compiler
} // namespace protobuf } // namespace protobuf
......
...@@ -46,6 +46,7 @@ class RepeatedPrimitiveFieldGenerator : public FieldGeneratorBase { ...@@ -46,6 +46,7 @@ class RepeatedPrimitiveFieldGenerator : public FieldGeneratorBase {
RepeatedPrimitiveFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal); RepeatedPrimitiveFieldGenerator(const FieldDescriptor* descriptor, int fieldOrdinal);
~RepeatedPrimitiveFieldGenerator(); ~RepeatedPrimitiveFieldGenerator();
virtual void GenerateCloningCode(io::Printer* printer);
virtual void GenerateMembers(io::Printer* printer); virtual void GenerateMembers(io::Printer* printer);
virtual void GenerateMergingCode(io::Printer* printer); virtual void GenerateMergingCode(io::Printer* printer);
virtual void GenerateParsingCode(io::Printer* printer); virtual void GenerateParsingCode(io::Printer* printer);
......
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