Commit 4041600a authored by Jisi Liu's avatar Jisi Liu

Merge branch '3.5.x' of github.com:google/protobuf into 3.5.x

parents 4493595f 2761122b
...@@ -62,6 +62,7 @@ ...@@ -62,6 +62,7 @@
C# C#
* Added unknown field support in JsonParser. * Added unknown field support in JsonParser.
* Fixed oneof message field merge. * Fixed oneof message field merge.
* Simplify parsing messages from array slices.
Ruby Ruby
* Unknown fields are now preserved by default. * Unknown fields are now preserved by default.
......
...@@ -1842,6 +1842,14 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner, ...@@ -1842,6 +1842,14 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
"optionalInt64": null, "optionalInt64": null,
"optionalUint32": null, "optionalUint32": null,
"optionalUint64": null, "optionalUint64": null,
"optionalSint32": null,
"optionalSint64": null,
"optionalFixed32": null,
"optionalFixed64": null,
"optionalSfixed32": null,
"optionalSfixed64": null,
"optionalFloat": null,
"optionalDouble": null,
"optionalBool": null, "optionalBool": null,
"optionalString": null, "optionalString": null,
"optionalBytes": null, "optionalBytes": null,
...@@ -1851,6 +1859,14 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner, ...@@ -1851,6 +1859,14 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
"repeatedInt64": null, "repeatedInt64": null,
"repeatedUint32": null, "repeatedUint32": null,
"repeatedUint64": null, "repeatedUint64": null,
"repeatedSint32": null,
"repeatedSint64": null,
"repeatedFixed32": null,
"repeatedFixed64": null,
"repeatedSfixed32": null,
"repeatedSfixed64": null,
"repeatedFloat": null,
"repeatedDouble": null,
"repeatedBool": null, "repeatedBool": null,
"repeatedString": null, "repeatedString": null,
"repeatedBytes": null, "repeatedBytes": null,
......
...@@ -53,6 +53,22 @@ namespace Google.Protobuf ...@@ -53,6 +53,22 @@ namespace Google.Protobuf
input.CheckReadEndOfStreamTag(); input.CheckReadEndOfStreamTag();
} }
/// <summary>
/// Merges data from the given byte array slice into an existing message.
/// </summary>
/// <param name="message">The message to merge the data into.</param>
/// <param name="data">The data containing the slice to merge, which must be protobuf-encoded binary data.</param>
/// <param name="offset">The offset of the slice to merge.</param>
/// <param name="length">The length of the slice to merge.</param>
public static void MergeFrom(this IMessage message, byte[] data, int offset, int length)
{
ProtoPreconditions.CheckNotNull(message, "message");
ProtoPreconditions.CheckNotNull(data, "data");
CodedInputStream input = new CodedInputStream(data, offset, length);
message.MergeFrom(input);
input.CheckReadEndOfStreamTag();
}
/// <summary> /// <summary>
/// Merges data from the given byte string into an existing message. /// Merges data from the given byte string into an existing message.
/// </summary> /// </summary>
......
...@@ -64,12 +64,25 @@ namespace Google.Protobuf ...@@ -64,12 +64,25 @@ namespace Google.Protobuf
/// <returns>The newly parsed message.</returns> /// <returns>The newly parsed message.</returns>
public IMessage ParseFrom(byte[] data) public IMessage ParseFrom(byte[] data)
{ {
ProtoPreconditions.CheckNotNull(data, "data");
IMessage message = factory(); IMessage message = factory();
message.MergeFrom(data); message.MergeFrom(data);
return message; return message;
} }
/// <summary>
/// Parses a message from a byte array slice.
/// </summary>
/// <param name="data">The byte array containing the message. Must not be null.</param>
/// <param name="offset">The offset of the slice to parse.</param>
/// <param name="length">The length of the slice to parse.</param>
/// <returns>The newly parsed message.</returns>
public IMessage ParseFrom(byte[] data, int offset, int length)
{
IMessage message = factory();
message.MergeFrom(data, offset, length);
return message;
}
/// <summary> /// <summary>
/// Parses a message from the given byte string. /// Parses a message from the given byte string.
/// </summary> /// </summary>
...@@ -77,7 +90,6 @@ namespace Google.Protobuf ...@@ -77,7 +90,6 @@ namespace Google.Protobuf
/// <returns>The parsed message.</returns> /// <returns>The parsed message.</returns>
public IMessage ParseFrom(ByteString data) public IMessage ParseFrom(ByteString data)
{ {
ProtoPreconditions.CheckNotNull(data, "data");
IMessage message = factory(); IMessage message = factory();
message.MergeFrom(data); message.MergeFrom(data);
return message; return message;
...@@ -191,12 +203,25 @@ namespace Google.Protobuf ...@@ -191,12 +203,25 @@ namespace Google.Protobuf
/// <returns>The newly parsed message.</returns> /// <returns>The newly parsed message.</returns>
public new T ParseFrom(byte[] data) public new T ParseFrom(byte[] data)
{ {
ProtoPreconditions.CheckNotNull(data, "data");
T message = factory(); T message = factory();
message.MergeFrom(data); message.MergeFrom(data);
return message; return message;
} }
/// <summary>
/// Parses a message from a byte array slice.
/// </summary>
/// <param name="data">The byte array containing the message. Must not be null.</param>
/// <param name="offset">The offset of the slice to parse.</param>
/// <param name="length">The length of the slice to parse.</param>
/// <returns>The newly parsed message.</returns>
public new T ParseFrom(byte[] data, int offset, int length)
{
T message = factory();
message.MergeFrom(data, offset, length);
return message;
}
/// <summary> /// <summary>
/// Parses a message from the given byte string. /// Parses a message from the given byte string.
/// </summary> /// </summary>
...@@ -204,7 +229,6 @@ namespace Google.Protobuf ...@@ -204,7 +229,6 @@ namespace Google.Protobuf
/// <returns>The parsed message.</returns> /// <returns>The parsed message.</returns>
public new T ParseFrom(ByteString data) public new T ParseFrom(ByteString data)
{ {
ProtoPreconditions.CheckNotNull(data, "data");
T message = factory(); T message = factory();
message.MergeFrom(data); message.MergeFrom(data);
return message; return message;
......
...@@ -833,6 +833,8 @@ class Message ...@@ -833,6 +833,8 @@ class Message
} }
return $value; return $value;
case GPBType::INT32: case GPBType::INT32:
case GPBType::SINT32:
case GPBType::SFIXED32:
if (is_null($value)) { if (is_null($value)) {
return $this->defaultValue($field); return $this->defaultValue($field);
} }
...@@ -850,6 +852,7 @@ class Message ...@@ -850,6 +852,7 @@ class Message
} }
return $value; return $value;
case GPBType::UINT32: case GPBType::UINT32:
case GPBType::FIXED32:
if (is_null($value)) { if (is_null($value)) {
return $this->defaultValue($field); return $this->defaultValue($field);
} }
...@@ -863,6 +866,8 @@ class Message ...@@ -863,6 +866,8 @@ class Message
} }
return $value; return $value;
case GPBType::INT64: case GPBType::INT64:
case GPBType::SINT64:
case GPBType::SFIXED64:
if (is_null($value)) { if (is_null($value)) {
return $this->defaultValue($field); return $this->defaultValue($field);
} }
...@@ -880,6 +885,7 @@ class Message ...@@ -880,6 +885,7 @@ class Message
} }
return $value; return $value;
case GPBType::UINT64: case GPBType::UINT64:
case GPBType::FIXED64:
if (is_null($value)) { if (is_null($value)) {
return $this->defaultValue($field); return $this->defaultValue($field);
} }
...@@ -895,11 +901,6 @@ class Message ...@@ -895,11 +901,6 @@ class Message
$value = bcsub($value, "18446744073709551616"); $value = bcsub($value, "18446744073709551616");
} }
return $value; return $value;
case GPBType::FIXED64:
if (is_null($value)) {
return $this->defaultValue($field);
}
return $value;
default: default:
return $value; return $value;
} }
......
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