org.red5.server.net.protocol.RTMPDecodeState Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ant-media-server-common Show documentation
Show all versions of ant-media-server-common Show documentation
Classes common for multiple Ant Media projects
/*
* RED5 Open Source Media Server - https://github.com/Red5/
*
* Copyright 2006-2016 by respective authors (see below). All rights reserved.
*
* Licensed 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 org.red5.server.net.protocol;
/**
* Represents current decode state of the protocol.
*/
public class RTMPDecodeState {
/**
* Decoding finished successfully state constant.
*/
public static byte DECODER_OK = 0x00;
/**
* Decoding continues state constant.
*/
public static byte DECODER_CONTINUE = 0x01;
/**
* Decoder is buffering state constant.
*/
public static byte DECODER_BUFFER = 0x02;
/**
* Session id to which this decoding state belongs.
*/
public final String sessionId;
/**
* Classes like the RTMP state object will extend this marker interface.
*/
private int decoderBufferAmount;
/**
* Current decoder state, decoder is stopped by default.
*/
private byte decoderState = DECODER_OK;
/**
* Names for the states.
*/
private static final String[] names = new String[]{"Ok", "Continue", "Buffer"};
public RTMPDecodeState(String sessionId) {
this.sessionId = sessionId;
}
/**
* Returns current buffer amount.
*
* @return Buffer amount
*/
public int getDecoderBufferAmount() {
return decoderBufferAmount;
}
/**
* Specifies buffer decoding amount
*
* @param amount Buffer decoding amount
*/
public void bufferDecoding(int amount) {
decoderState = DECODER_BUFFER;
decoderBufferAmount = amount;
}
/**
* Set decoding state as "needed to be continued".
*/
public void continueDecoding() {
decoderState = DECODER_CONTINUE;
}
/**
* Checks whether remaining buffer size is greater or equal than buffer amount and so if it makes sense to start decoding.
*
* @param remaining Remaining buffer size
* @return true if there is data to decode, false otherwise
*/
public boolean canStartDecoding(int remaining) {
return remaining >= decoderBufferAmount;
}
/**
* Starts decoding. Sets state to "ready" and clears buffer amount.
*/
public void startDecoding() {
decoderState = DECODER_OK;
decoderBufferAmount = 0;
}
/**
* Checks whether decoding is complete.
*
* @return true if decoding has finished, false otherwise
*/
public boolean hasDecodedObject() {
return (decoderState == DECODER_OK);
}
/**
* Checks whether decoding process can be continued.
*
* @return true if decoding can be continued, false otherwise
*/
public boolean canContinueDecoding() {
return (decoderState != DECODER_BUFFER);
}
/**
* @return the sessionId
*/
public String getSessionId() {
return sessionId;
}
/* (non-Javadoc)
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
return "RTMPDecodeState [sessionId=" + sessionId + ", decoderState=" + names[decoderState] + ", decoderBufferAmount=" + decoderBufferAmount + "]";
}
}