StreamByteDistributor Type — netty Architecture
Architecture documentation for the StreamByteDistributor type/interface in StreamByteDistributor.java from the netty codebase.
Entity Profile
Dependency Diagram
graph TD 0c1b5c9e_091c_86f4_971a_96b06dc76992["StreamByteDistributor"] ed6553eb_f96d_ef7e_dd46_da04ed6bc35e["StreamByteDistributor.java"] 0c1b5c9e_091c_86f4_971a_96b06dc76992 -->|defined in| ed6553eb_f96d_ef7e_dd46_da04ed6bc35e style 0c1b5c9e_091c_86f4_971a_96b06dc76992 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
codec-http2/src/main/java/io/netty/handler/codec/http2/StreamByteDistributor.java lines 22–109
public interface StreamByteDistributor {
/**
* State information for the stream, indicating the number of bytes that are currently
* streamable. This is provided to the {@link #updateStreamableBytes(StreamState)} method.
*/
interface StreamState {
/**
* Gets the stream this state is associated with.
*/
Http2Stream stream();
/**
* Get the amount of bytes this stream has pending to send. The actual amount written must not exceed
* {@link #windowSize()}!
* @return The amount of bytes this stream has pending to send.
* @see Http2CodecUtil#streamableBytes(StreamState)
*/
long pendingBytes();
/**
* Indicates whether or not there are frames pending for this stream.
*/
boolean hasFrame();
/**
* The size (in bytes) of the stream's flow control window. The amount written must not exceed this amount!
* <p>A {@link StreamByteDistributor} needs to know the stream's window size in order to avoid allocating bytes
* if the window size is negative. The window size being {@code 0} may also be significant to determine when if
* an stream has been given a chance to write an empty frame, and also enables optimizations like not writing
* empty frames in some situations (don't write headers until data can also be written).
* @return the size of the stream's flow control window.
* @see Http2CodecUtil#streamableBytes(StreamState)
*/
int windowSize();
}
/**
* Object that performs the writing of the bytes that have been allocated for a stream.
*/
interface Writer {
/**
* Writes the allocated bytes for this stream.
* <p>
* Any {@link Throwable} thrown from this method is considered a programming error.
* A {@code GOAWAY} frame will be sent and the will be connection closed.
* @param stream the stream for which to perform the write.
* @param numBytes the number of bytes to write.
*/
void write(Http2Stream stream, int numBytes);
}
/**
* Called when the streamable bytes for a stream has changed. Until this
* method is called for the first time for a give stream, the stream is assumed to have no
* streamable bytes.
*/
void updateStreamableBytes(StreamState state);
/**
* Explicitly update the dependency tree. This method is called independently of stream state changes.
* @param childStreamId The stream identifier associated with the child stream.
* @param parentStreamId The stream identifier associated with the parent stream. May be {@code 0},
* to make {@code childStreamId} and immediate child of the connection.
* @param weight The weight which is used relative to other child streams for {@code parentStreamId}. This value
* must be between 1 and 256 (inclusive).
* @param exclusive If {@code childStreamId} should be the exclusive dependency of {@code parentStreamId}.
*/
void updateDependencyTree(int childStreamId, int parentStreamId, short weight, boolean exclusive);
/**
* Distributes up to {@code maxBytes} to those streams containing streamable bytes and
* iterates across those streams to write the appropriate bytes. Criteria for
* traversing streams is undefined and it is up to the implementation to determine when to stop
* at a given stream.
*
* <p>The streamable bytes are not automatically updated by calling this method. It is up to the
* caller to indicate the number of bytes streamable after the write by calling
* {@link #updateStreamableBytes(StreamState)}.
*
* @param maxBytes the maximum number of bytes to write.
Source
Frequently Asked Questions
What is the StreamByteDistributor type?
StreamByteDistributor is a type/interface in the netty codebase, defined in codec-http2/src/main/java/io/netty/handler/codec/http2/StreamByteDistributor.java.
Where is StreamByteDistributor defined?
StreamByteDistributor is defined in codec-http2/src/main/java/io/netty/handler/codec/http2/StreamByteDistributor.java at line 22.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free