aboutsummaryrefslogtreecommitdiff
path: root/csharp/src/ProtocolBuffers/Extensions.cs
diff options
context:
space:
mode:
authorJon Skeet <skeet@pobox.com>2015-06-09 19:30:44 +0100
committerJon Skeet <skeet@pobox.com>2015-06-09 19:30:44 +0100
commite38294a62d7f37c0661273a9a26fda16d557423f (patch)
tree316989251907553408e7b32a12792f496333e075 /csharp/src/ProtocolBuffers/Extensions.cs
parentf52426827e4d5e8da7d205af538799740b5199b9 (diff)
downloadprotobuf-e38294a62d7f37c0661273a9a26fda16d557423f.tar.gz
protobuf-e38294a62d7f37c0661273a9a26fda16d557423f.tar.bz2
protobuf-e38294a62d7f37c0661273a9a26fda16d557423f.zip
First pass at the mutable API. Quite a bit more to do - in particular, it's pretty slow right now.
Diffstat (limited to 'csharp/src/ProtocolBuffers/Extensions.cs')
-rw-r--r--csharp/src/ProtocolBuffers/Extensions.cs70
1 files changed, 70 insertions, 0 deletions
diff --git a/csharp/src/ProtocolBuffers/Extensions.cs b/csharp/src/ProtocolBuffers/Extensions.cs
new file mode 100644
index 00000000..29288f51
--- /dev/null
+++ b/csharp/src/ProtocolBuffers/Extensions.cs
@@ -0,0 +1,70 @@
+using System.IO;
+
+namespace Google.Protobuf
+{
+ // TODO: MessageExtensions?
+ public static class Extensions
+ {
+ public static void MergeFrom(this IMessage message, byte[] data)
+ {
+ CodedInputStream input = CodedInputStream.CreateInstance(data);
+ message.MergeFrom(input);
+ input.CheckLastTagWas(0);
+ }
+
+ public static void MergeFrom(this IMessage message, ByteString data)
+ {
+ CodedInputStream input = data.CreateCodedInput();
+ message.MergeFrom(input);
+ input.CheckLastTagWas(0);
+ }
+
+ public static void MergeFrom(this IMessage message, Stream input)
+ {
+ CodedInputStream codedInput = CodedInputStream.CreateInstance(input);
+ message.MergeFrom(codedInput);
+ codedInput.CheckLastTagWas(0);
+ }
+
+ public static void MergeDelimitedFrom(this IMessage message, Stream input)
+ {
+ int size = (int)CodedInputStream.ReadRawVarint32(input);
+ Stream limitedStream = new LimitedInputStream(input, size);
+ message.MergeFrom(limitedStream);
+ }
+
+ public static byte[] ToByteArray(this IMessage message)
+ {
+ byte[] result = new byte[message.CalculateSize()];
+ CodedOutputStream output = CodedOutputStream.CreateInstance(result);
+ message.WriteTo(output);
+ output.CheckNoSpaceLeft();
+ return result;
+ }
+
+ public static void WriteTo(this IMessage message, Stream output)
+ {
+ CodedOutputStream codedOutput = CodedOutputStream.CreateInstance(output);
+ message.WriteTo(codedOutput);
+ codedOutput.Flush();
+ }
+
+ public static void WriteTo(this IMessage message, ICodedOutputStream output)
+ {
+ message.WriteTo(output);
+ }
+
+ public static void WriteDelimitedTo(this IMessage message, Stream output)
+ {
+ CodedOutputStream codedOutput = CodedOutputStream.CreateInstance(output);
+ codedOutput.WriteRawVarint32((uint)message.CalculateSize());
+ message.WriteTo(codedOutput);
+ codedOutput.Flush();
+ }
+
+ public static ByteString ToByteString(this IMessage message)
+ {
+ return ByteString.AttachBytes(message.ToByteArray());
+ }
+ }
+}