001 /**
002 *
003 * Licensed to the Apache Software Foundation (ASF) under one or more
004 * contributor license agreements. See the NOTICE file distributed with
005 * this work for additional information regarding copyright ownership.
006 * The ASF licenses this file to You under the Apache License, Version 2.0
007 * (the "License"); you may not use this file except in compliance with
008 * the License. You may obtain a copy of the License at
009 *
010 * http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing, software
013 * distributed under the License is distributed on an "AS IS" BASIS,
014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015 * See the License for the specific language governing permissions and
016 * limitations under the License.
017 */
018
019 package org.apache.activemq.openwire.v5;
020
021 import java.io.DataInput;
022 import java.io.DataOutput;
023 import java.io.IOException;
024
025 import org.apache.activemq.openwire.*;
026 import org.apache.activemq.command.*;
027
028
029
030 /**
031 * Marshalling code for Open Wire Format for MessageMarshaller
032 *
033 *
034 * NOTE!: This file is auto generated - do not modify!
035 * if you need to make a change, please see the modify the groovy scripts in the
036 * under src/gram/script and then use maven openwire:generate to regenerate
037 * this file.
038 *
039 *
040 */
041 public abstract class MessageMarshaller extends BaseCommandMarshaller {
042
043 /**
044 * Un-marshal an object instance from the data input stream
045 *
046 * @param o the object to un-marshal
047 * @param dataIn the data input stream to build the object from
048 * @throws IOException
049 */
050 public void tightUnmarshal(OpenWireFormat wireFormat, Object o, DataInput dataIn, BooleanStream bs) throws IOException {
051 super.tightUnmarshal(wireFormat, o, dataIn, bs);
052
053 Message info = (Message)o;
054
055 info.beforeUnmarshall(wireFormat);
056
057 info.setProducerId((org.apache.activemq.command.ProducerId) tightUnmarsalCachedObject(wireFormat, dataIn, bs));
058 info.setDestination((org.apache.activemq.command.ActiveMQDestination) tightUnmarsalCachedObject(wireFormat, dataIn, bs));
059 info.setTransactionId((org.apache.activemq.command.TransactionId) tightUnmarsalCachedObject(wireFormat, dataIn, bs));
060 info.setOriginalDestination((org.apache.activemq.command.ActiveMQDestination) tightUnmarsalCachedObject(wireFormat, dataIn, bs));
061 info.setMessageId((org.apache.activemq.command.MessageId) tightUnmarsalNestedObject(wireFormat, dataIn, bs));
062 info.setOriginalTransactionId((org.apache.activemq.command.TransactionId) tightUnmarsalCachedObject(wireFormat, dataIn, bs));
063 info.setGroupID(tightUnmarshalString(dataIn, bs));
064 info.setGroupSequence(dataIn.readInt());
065 info.setCorrelationId(tightUnmarshalString(dataIn, bs));
066 info.setPersistent(bs.readBoolean());
067 info.setExpiration(tightUnmarshalLong(wireFormat, dataIn, bs));
068 info.setPriority(dataIn.readByte());
069 info.setReplyTo((org.apache.activemq.command.ActiveMQDestination) tightUnmarsalNestedObject(wireFormat, dataIn, bs));
070 info.setTimestamp(tightUnmarshalLong(wireFormat, dataIn, bs));
071 info.setType(tightUnmarshalString(dataIn, bs));
072 info.setContent(tightUnmarshalByteSequence(dataIn, bs));
073 info.setMarshalledProperties(tightUnmarshalByteSequence(dataIn, bs));
074 info.setDataStructure((org.apache.activemq.command.DataStructure) tightUnmarsalNestedObject(wireFormat, dataIn, bs));
075 info.setTargetConsumerId((org.apache.activemq.command.ConsumerId) tightUnmarsalCachedObject(wireFormat, dataIn, bs));
076 info.setCompressed(bs.readBoolean());
077 info.setRedeliveryCounter(dataIn.readInt());
078
079 if (bs.readBoolean()) {
080 short size = dataIn.readShort();
081 org.apache.activemq.command.BrokerId value[] = new org.apache.activemq.command.BrokerId[size];
082 for( int i=0; i < size; i++ ) {
083 value[i] = (org.apache.activemq.command.BrokerId) tightUnmarsalNestedObject(wireFormat,dataIn, bs);
084 }
085 info.setBrokerPath(value);
086 }
087 else {
088 info.setBrokerPath(null);
089 }
090 info.setArrival(tightUnmarshalLong(wireFormat, dataIn, bs));
091 info.setUserID(tightUnmarshalString(dataIn, bs));
092 info.setRecievedByDFBridge(bs.readBoolean());
093 info.setDroppable(bs.readBoolean());
094
095 if (bs.readBoolean()) {
096 short size = dataIn.readShort();
097 org.apache.activemq.command.BrokerId value[] = new org.apache.activemq.command.BrokerId[size];
098 for( int i=0; i < size; i++ ) {
099 value[i] = (org.apache.activemq.command.BrokerId) tightUnmarsalNestedObject(wireFormat,dataIn, bs);
100 }
101 info.setCluster(value);
102 }
103 else {
104 info.setCluster(null);
105 }
106 info.setBrokerInTime(tightUnmarshalLong(wireFormat, dataIn, bs));
107 info.setBrokerOutTime(tightUnmarshalLong(wireFormat, dataIn, bs));
108
109 info.afterUnmarshall(wireFormat);
110
111 }
112
113
114 /**
115 * Write the booleans that this object uses to a BooleanStream
116 */
117 public int tightMarshal1(OpenWireFormat wireFormat, Object o, BooleanStream bs) throws IOException {
118
119 Message info = (Message)o;
120
121 info.beforeMarshall(wireFormat);
122
123 int rc = super.tightMarshal1(wireFormat, o, bs);
124 rc += tightMarshalCachedObject1(wireFormat, (DataStructure)info.getProducerId(), bs);
125 rc += tightMarshalCachedObject1(wireFormat, (DataStructure)info.getDestination(), bs);
126 rc += tightMarshalCachedObject1(wireFormat, (DataStructure)info.getTransactionId(), bs);
127 rc += tightMarshalCachedObject1(wireFormat, (DataStructure)info.getOriginalDestination(), bs);
128 rc += tightMarshalNestedObject1(wireFormat, (DataStructure)info.getMessageId(), bs);
129 rc += tightMarshalCachedObject1(wireFormat, (DataStructure)info.getOriginalTransactionId(), bs);
130 rc += tightMarshalString1(info.getGroupID(), bs);
131 rc += tightMarshalString1(info.getCorrelationId(), bs);
132 bs.writeBoolean(info.isPersistent());
133 rc+=tightMarshalLong1(wireFormat, info.getExpiration(), bs);
134 rc += tightMarshalNestedObject1(wireFormat, (DataStructure)info.getReplyTo(), bs);
135 rc+=tightMarshalLong1(wireFormat, info.getTimestamp(), bs);
136 rc += tightMarshalString1(info.getType(), bs);
137 rc += tightMarshalByteSequence1(info.getContent(), bs);
138 rc += tightMarshalByteSequence1(info.getMarshalledProperties(), bs);
139 rc += tightMarshalNestedObject1(wireFormat, (DataStructure)info.getDataStructure(), bs);
140 rc += tightMarshalCachedObject1(wireFormat, (DataStructure)info.getTargetConsumerId(), bs);
141 bs.writeBoolean(info.isCompressed());
142 rc += tightMarshalObjectArray1(wireFormat, info.getBrokerPath(), bs);
143 rc+=tightMarshalLong1(wireFormat, info.getArrival(), bs);
144 rc += tightMarshalString1(info.getUserID(), bs);
145 bs.writeBoolean(info.isRecievedByDFBridge());
146 bs.writeBoolean(info.isDroppable());
147 rc += tightMarshalObjectArray1(wireFormat, info.getCluster(), bs);
148 rc+=tightMarshalLong1(wireFormat, info.getBrokerInTime(), bs);
149 rc+=tightMarshalLong1(wireFormat, info.getBrokerOutTime(), bs);
150
151 return rc + 9;
152 }
153
154 /**
155 * Write a object instance to data output stream
156 *
157 * @param o the instance to be marshaled
158 * @param dataOut the output stream
159 * @throws IOException thrown if an error occurs
160 */
161 public void tightMarshal2(OpenWireFormat wireFormat, Object o, DataOutput dataOut, BooleanStream bs) throws IOException {
162 super.tightMarshal2(wireFormat, o, dataOut, bs);
163
164 Message info = (Message)o;
165 tightMarshalCachedObject2(wireFormat, (DataStructure)info.getProducerId(), dataOut, bs);
166 tightMarshalCachedObject2(wireFormat, (DataStructure)info.getDestination(), dataOut, bs);
167 tightMarshalCachedObject2(wireFormat, (DataStructure)info.getTransactionId(), dataOut, bs);
168 tightMarshalCachedObject2(wireFormat, (DataStructure)info.getOriginalDestination(), dataOut, bs);
169 tightMarshalNestedObject2(wireFormat, (DataStructure)info.getMessageId(), dataOut, bs);
170 tightMarshalCachedObject2(wireFormat, (DataStructure)info.getOriginalTransactionId(), dataOut, bs);
171 tightMarshalString2(info.getGroupID(), dataOut, bs);
172 dataOut.writeInt(info.getGroupSequence());
173 tightMarshalString2(info.getCorrelationId(), dataOut, bs);
174 bs.readBoolean();
175 tightMarshalLong2(wireFormat, info.getExpiration(), dataOut, bs);
176 dataOut.writeByte(info.getPriority());
177 tightMarshalNestedObject2(wireFormat, (DataStructure)info.getReplyTo(), dataOut, bs);
178 tightMarshalLong2(wireFormat, info.getTimestamp(), dataOut, bs);
179 tightMarshalString2(info.getType(), dataOut, bs);
180 tightMarshalByteSequence2(info.getContent(), dataOut, bs);
181 tightMarshalByteSequence2(info.getMarshalledProperties(), dataOut, bs);
182 tightMarshalNestedObject2(wireFormat, (DataStructure)info.getDataStructure(), dataOut, bs);
183 tightMarshalCachedObject2(wireFormat, (DataStructure)info.getTargetConsumerId(), dataOut, bs);
184 bs.readBoolean();
185 dataOut.writeInt(info.getRedeliveryCounter());
186 tightMarshalObjectArray2(wireFormat, info.getBrokerPath(), dataOut, bs);
187 tightMarshalLong2(wireFormat, info.getArrival(), dataOut, bs);
188 tightMarshalString2(info.getUserID(), dataOut, bs);
189 bs.readBoolean();
190 bs.readBoolean();
191 tightMarshalObjectArray2(wireFormat, info.getCluster(), dataOut, bs);
192 tightMarshalLong2(wireFormat, info.getBrokerInTime(), dataOut, bs);
193 tightMarshalLong2(wireFormat, info.getBrokerOutTime(), dataOut, bs);
194
195 info.afterMarshall(wireFormat);
196
197 }
198
199 /**
200 * Un-marshal an object instance from the data input stream
201 *
202 * @param o the object to un-marshal
203 * @param dataIn the data input stream to build the object from
204 * @throws IOException
205 */
206 public void looseUnmarshal(OpenWireFormat wireFormat, Object o, DataInput dataIn) throws IOException {
207 super.looseUnmarshal(wireFormat, o, dataIn);
208
209 Message info = (Message)o;
210
211 info.beforeUnmarshall(wireFormat);
212
213 info.setProducerId((org.apache.activemq.command.ProducerId) looseUnmarsalCachedObject(wireFormat, dataIn));
214 info.setDestination((org.apache.activemq.command.ActiveMQDestination) looseUnmarsalCachedObject(wireFormat, dataIn));
215 info.setTransactionId((org.apache.activemq.command.TransactionId) looseUnmarsalCachedObject(wireFormat, dataIn));
216 info.setOriginalDestination((org.apache.activemq.command.ActiveMQDestination) looseUnmarsalCachedObject(wireFormat, dataIn));
217 info.setMessageId((org.apache.activemq.command.MessageId) looseUnmarsalNestedObject(wireFormat, dataIn));
218 info.setOriginalTransactionId((org.apache.activemq.command.TransactionId) looseUnmarsalCachedObject(wireFormat, dataIn));
219 info.setGroupID(looseUnmarshalString(dataIn));
220 info.setGroupSequence(dataIn.readInt());
221 info.setCorrelationId(looseUnmarshalString(dataIn));
222 info.setPersistent(dataIn.readBoolean());
223 info.setExpiration(looseUnmarshalLong(wireFormat, dataIn));
224 info.setPriority(dataIn.readByte());
225 info.setReplyTo((org.apache.activemq.command.ActiveMQDestination) looseUnmarsalNestedObject(wireFormat, dataIn));
226 info.setTimestamp(looseUnmarshalLong(wireFormat, dataIn));
227 info.setType(looseUnmarshalString(dataIn));
228 info.setContent(looseUnmarshalByteSequence(dataIn));
229 info.setMarshalledProperties(looseUnmarshalByteSequence(dataIn));
230 info.setDataStructure((org.apache.activemq.command.DataStructure) looseUnmarsalNestedObject(wireFormat, dataIn));
231 info.setTargetConsumerId((org.apache.activemq.command.ConsumerId) looseUnmarsalCachedObject(wireFormat, dataIn));
232 info.setCompressed(dataIn.readBoolean());
233 info.setRedeliveryCounter(dataIn.readInt());
234
235 if (dataIn.readBoolean()) {
236 short size = dataIn.readShort();
237 org.apache.activemq.command.BrokerId value[] = new org.apache.activemq.command.BrokerId[size];
238 for( int i=0; i < size; i++ ) {
239 value[i] = (org.apache.activemq.command.BrokerId) looseUnmarsalNestedObject(wireFormat,dataIn);
240 }
241 info.setBrokerPath(value);
242 }
243 else {
244 info.setBrokerPath(null);
245 }
246 info.setArrival(looseUnmarshalLong(wireFormat, dataIn));
247 info.setUserID(looseUnmarshalString(dataIn));
248 info.setRecievedByDFBridge(dataIn.readBoolean());
249 info.setDroppable(dataIn.readBoolean());
250
251 if (dataIn.readBoolean()) {
252 short size = dataIn.readShort();
253 org.apache.activemq.command.BrokerId value[] = new org.apache.activemq.command.BrokerId[size];
254 for( int i=0; i < size; i++ ) {
255 value[i] = (org.apache.activemq.command.BrokerId) looseUnmarsalNestedObject(wireFormat,dataIn);
256 }
257 info.setCluster(value);
258 }
259 else {
260 info.setCluster(null);
261 }
262 info.setBrokerInTime(looseUnmarshalLong(wireFormat, dataIn));
263 info.setBrokerOutTime(looseUnmarshalLong(wireFormat, dataIn));
264
265 info.afterUnmarshall(wireFormat);
266
267 }
268
269
270 /**
271 * Write the booleans that this object uses to a BooleanStream
272 */
273 public void looseMarshal(OpenWireFormat wireFormat, Object o, DataOutput dataOut) throws IOException {
274
275 Message info = (Message)o;
276
277 info.beforeMarshall(wireFormat);
278
279 super.looseMarshal(wireFormat, o, dataOut);
280 looseMarshalCachedObject(wireFormat, (DataStructure)info.getProducerId(), dataOut);
281 looseMarshalCachedObject(wireFormat, (DataStructure)info.getDestination(), dataOut);
282 looseMarshalCachedObject(wireFormat, (DataStructure)info.getTransactionId(), dataOut);
283 looseMarshalCachedObject(wireFormat, (DataStructure)info.getOriginalDestination(), dataOut);
284 looseMarshalNestedObject(wireFormat, (DataStructure)info.getMessageId(), dataOut);
285 looseMarshalCachedObject(wireFormat, (DataStructure)info.getOriginalTransactionId(), dataOut);
286 looseMarshalString(info.getGroupID(), dataOut);
287 dataOut.writeInt(info.getGroupSequence());
288 looseMarshalString(info.getCorrelationId(), dataOut);
289 dataOut.writeBoolean(info.isPersistent());
290 looseMarshalLong(wireFormat, info.getExpiration(), dataOut);
291 dataOut.writeByte(info.getPriority());
292 looseMarshalNestedObject(wireFormat, (DataStructure)info.getReplyTo(), dataOut);
293 looseMarshalLong(wireFormat, info.getTimestamp(), dataOut);
294 looseMarshalString(info.getType(), dataOut);
295 looseMarshalByteSequence(wireFormat, info.getContent(), dataOut);
296 looseMarshalByteSequence(wireFormat, info.getMarshalledProperties(), dataOut);
297 looseMarshalNestedObject(wireFormat, (DataStructure)info.getDataStructure(), dataOut);
298 looseMarshalCachedObject(wireFormat, (DataStructure)info.getTargetConsumerId(), dataOut);
299 dataOut.writeBoolean(info.isCompressed());
300 dataOut.writeInt(info.getRedeliveryCounter());
301 looseMarshalObjectArray(wireFormat, info.getBrokerPath(), dataOut);
302 looseMarshalLong(wireFormat, info.getArrival(), dataOut);
303 looseMarshalString(info.getUserID(), dataOut);
304 dataOut.writeBoolean(info.isRecievedByDFBridge());
305 dataOut.writeBoolean(info.isDroppable());
306 looseMarshalObjectArray(wireFormat, info.getCluster(), dataOut);
307 looseMarshalLong(wireFormat, info.getBrokerInTime(), dataOut);
308 looseMarshalLong(wireFormat, info.getBrokerOutTime(), dataOut);
309
310 }
311 }