/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.hawtjms.jms.message;
import javax.jms.JMSException;
import javax.jms.MessageNotWriteableException;
import javax.jms.TextMessage;
public class JmsTextMessage extends JmsMessage implements TextMessage {
protected String text;
public JmsTextMessage(JmsMessageFacade facade) {
super(facade);
}
@Override
public JmsMessage copy() throws JMSException {
JmsTextMessage other = new JmsTextMessage(facade.copy());
other.copy(this);
return other;
}
private void copy(JmsTextMessage other) throws JMSException {
super.copy(other);
this.internalSetText(other.internalGetText());
}
@Override
public void setText(String text) throws MessageNotWriteableException {
checkReadOnlyBody();
this.text = text;
}
@Override
public String getText() throws JMSException {
return text;
}
/**
* Clears out the message body. Clearing a message's body does not clear its
* header values or property entries.
* <p/>
* <p/>
* If this message body was read-only, calling this method leaves the
* message body in the same state as an empty body in a newly created
* message.
*
* @throws JMSException
* if the JMS provider fails to clear the message body due to some
* internal error.
*/
@Override
public void clearBody() throws JMSException {
super.clearBody();
this.internalSetText(null);
}
@Override
public String toString() {
return super.toString() + ":text=" + internalGetText();
}
/**
* Internal version of the setText method that will not throw even if the message
* is in read-only mode. The method allows a sub-class to provide it's own set
* method for the text payload of the message.
*
* @param text
* the new value to store in this text message.
*/
protected void internalSetText(String text) {
this.text = text;
}
/**
* Internal version of the getText method that can be overridden by a subclass to
* allow for accessing the text directly from a protocols own Message type.
*
* @return the text content of the message.
*/
protected String internalGetText() {
return this.text;
}
}