2010-06-23: Michael Barker <mike@middlesoft.co.uk>
[mono.git] / mcs / class / RabbitMQ.Client / src / client / content / StreamMessageBuilder.cs
1 // This source code is dual-licensed under the Apache License, version
2 // 2.0, and the Mozilla Public License, version 1.1.
3 //
4 // The APL v2.0:
5 //
6 //---------------------------------------------------------------------------
7 //   Copyright (C) 2007-2010 LShift Ltd., Cohesive Financial
8 //   Technologies LLC., and Rabbit Technologies Ltd.
9 //
10 //   Licensed under the Apache License, Version 2.0 (the "License");
11 //   you may not use this file except in compliance with the License.
12 //   You may obtain a copy of the License at
13 //
14 //       http://www.apache.org/licenses/LICENSE-2.0
15 //
16 //   Unless required by applicable law or agreed to in writing, software
17 //   distributed under the License is distributed on an "AS IS" BASIS,
18 //   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 //   See the License for the specific language governing permissions and
20 //   limitations under the License.
21 //---------------------------------------------------------------------------
22 //
23 // The MPL v1.1:
24 //
25 //---------------------------------------------------------------------------
26 //   The contents of this file are subject to the Mozilla Public License
27 //   Version 1.1 (the "License"); you may not use this file except in
28 //   compliance with the License. You may obtain a copy of the License at
29 //   http://www.rabbitmq.com/mpl.html
30 //
31 //   Software distributed under the License is distributed on an "AS IS"
32 //   basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
33 //   License for the specific language governing rights and limitations
34 //   under the License.
35 //
36 //   The Original Code is The RabbitMQ .NET Client.
37 //
38 //   The Initial Developers of the Original Code are LShift Ltd,
39 //   Cohesive Financial Technologies LLC, and Rabbit Technologies Ltd.
40 //
41 //   Portions created before 22-Nov-2008 00:00:00 GMT by LShift Ltd,
42 //   Cohesive Financial Technologies LLC, or Rabbit Technologies Ltd
43 //   are Copyright (C) 2007-2008 LShift Ltd, Cohesive Financial
44 //   Technologies LLC, and Rabbit Technologies Ltd.
45 //
46 //   Portions created by LShift Ltd are Copyright (C) 2007-2010 LShift
47 //   Ltd. Portions created by Cohesive Financial Technologies LLC are
48 //   Copyright (C) 2007-2010 Cohesive Financial Technologies
49 //   LLC. Portions created by Rabbit Technologies Ltd are Copyright
50 //   (C) 2007-2010 Rabbit Technologies Ltd.
51 //
52 //   All Rights Reserved.
53 //
54 //   Contributor(s): ______________________________________.
55 //
56 //---------------------------------------------------------------------------
57 using System;
58 using System.IO;
59
60 using RabbitMQ.Client;
61
62 namespace RabbitMQ.Client.Content {
63     ///<summary>Constructs AMQP Basic-class messages binary-compatible
64     ///with QPid's "StreamMessage" wire encoding.</summary>
65     public class StreamMessageBuilder: BasicMessageBuilder, IStreamMessageBuilder {
66         ///<summary>MIME type associated with QPid StreamMessages.</summary>
67         public readonly static string MimeType = "jms/stream-message";
68
69         ///<summary>Construct an instance for writing. See superclass.</summary>
70         public StreamMessageBuilder(IModel model)
71             : base(model)
72         {}
73
74         ///<summary>Construct an instance for writing. See superclass.</summary>
75         public StreamMessageBuilder(IModel model, int initialAccumulatorSize)
76             : base(model, initialAccumulatorSize)
77         {}
78
79         ///<summary>Override superclass method to answer our characteristic MIME type.</summary>
80         public override string GetDefaultContentType() {
81             return MimeType;
82         }
83
84         ///<summary>Writes a bool value into the message body being assembled.</summary>
85         public IStreamMessageBuilder WriteBool(bool value) {
86             StreamWireFormatting.WriteBool(Writer, value);
87             return this;
88         }
89
90         ///<summary>Writes an int value into the message body being assembled.</summary>
91         public IStreamMessageBuilder WriteInt32(int value) {
92             StreamWireFormatting.WriteInt32(Writer, value);
93             return this;
94         }
95
96         ///<summary>Writes a short value into the message body being assembled.</summary>
97         public IStreamMessageBuilder WriteInt16(short value) {
98             StreamWireFormatting.WriteInt16(Writer, value);
99             return this;
100         }
101
102         ///<summary>Writes a byte value into the message body being assembled.</summary>
103         public IStreamMessageBuilder WriteByte(byte value) {
104             StreamWireFormatting.WriteByte(Writer, value);
105             return this;
106         }
107
108         ///<summary>Writes a char value into the message body being assembled.</summary>
109         public IStreamMessageBuilder WriteChar(char value) {
110             StreamWireFormatting.WriteChar(Writer, value);
111             return this;
112         }
113
114         ///<summary>Writes a long value into the message body being assembled.</summary>
115         public IStreamMessageBuilder WriteInt64(long value) {
116             StreamWireFormatting.WriteInt64(Writer, value);
117             return this;
118         }
119
120         ///<summary>Writes a float value into the message body being assembled.</summary>
121         public IStreamMessageBuilder WriteSingle(float value) {
122             StreamWireFormatting.WriteSingle(Writer, value);
123             return this;
124         }
125
126         ///<summary>Writes a double value into the message body being assembled.</summary>
127         public IStreamMessageBuilder WriteDouble(double value) {
128             StreamWireFormatting.WriteDouble(Writer, value);
129             return this;
130         }
131
132         ///<summary>Writes a section of a byte array into the message body being assembled.</summary>
133         public IStreamMessageBuilder WriteBytes(byte[] source, int offset, int count) {
134             StreamWireFormatting.WriteBytes(Writer, source, offset, count);
135             return this;
136         }
137
138         ///<summary>Writes a byte array into the message body being assembled.</summary>
139         public IStreamMessageBuilder WriteBytes(byte[] source) {
140             StreamWireFormatting.WriteBytes(Writer, source);
141             return this;
142         }
143
144         ///<summary>Writes a string value into the message body being assembled.</summary>
145         public IStreamMessageBuilder WriteString(string value) {
146             StreamWireFormatting.WriteString(Writer, value);
147             return this;
148         }
149
150         ///<summary>Writes an object value into the message body being assembled.</summary>
151         ///<remarks>
152         /// The only permitted types are bool, int, short, byte, char,
153         /// long, float, double, byte[] and string.
154         ///</remarks>
155         public IStreamMessageBuilder WriteObject(object value) {
156             StreamWireFormatting.WriteObject(Writer, value);
157             return this;
158         }
159
160         ///<summary>Writes objects using WriteObject(), one after the
161         ///other. No length indicator is written. See also
162         ///IStreamMessageReader.ReadObjects().</summary>
163         public IStreamMessageBuilder WriteObjects(params object[] values) {
164             foreach (object val in values) {
165                 WriteObject(val);
166             }
167             return this;
168         }
169     }
170 }