blob: df1e10e2c415caba67027a85613a653e2dac2a27 [file] [log] [blame]
csharptest71f662c2011-05-20 15:15:34 -05001#region Copyright notice and license
2
3// Protocol Buffers - Google's data interchange format
4// Copyright 2008 Google Inc. All rights reserved.
5// http://github.com/jskeet/dotnet-protobufs/
6// Original C++/Java/Python code:
7// http://code.google.com/p/protobuf/
8//
9// Redistribution and use in source and binary forms, with or without
10// modification, are permitted provided that the following conditions are
11// met:
12//
13// * Redistributions of source code must retain the above copyright
14// notice, this list of conditions and the following disclaimer.
15// * Redistributions in binary form must reproduce the above
16// copyright notice, this list of conditions and the following disclaimer
17// in the documentation and/or other materials provided with the
18// distribution.
19// * Neither the name of Google Inc. nor the names of its
20// contributors may be used to endorse or promote products derived from
21// this software without specific prior written permission.
22//
23// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34
35#endregion
36
37using System.IO;
38
39namespace Google.ProtocolBuffers
40{
41 /// <summary>
42 /// Writes multiple messages to the same stream. Each message is written
43 /// as if it were an element of a repeated field 1 in a larger protocol buffer.
44 /// This class takes no ownership of the stream it is given; it never closes the
45 /// stream.
46 /// </summary>
47 public sealed class MessageStreamWriter<T> where T : IMessage<T>
48 {
49 private readonly CodedOutputStream codedOutput;
50
51 /// <summary>
52 /// Creates an instance which writes to the given stream.
53 /// </summary>
54 /// <param name="output">Stream to write messages to.</param>
55 public MessageStreamWriter(Stream output)
56 {
57 codedOutput = CodedOutputStream.CreateInstance(output);
58 }
59
60 public void Write(T message)
61 {
62 codedOutput.WriteMessage(1, message);
63 }
64
65 public void Flush()
66 {
67 codedOutput.Flush();
68 }
69 }
70}