/* * Copyright 2014-2017 Real Logic Ltd. * * 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 io.aeron.logbuffer; import org.agrona.DirectBuffer; /** * Handler for reading data that is coming from a log buffer. The frame will either contain a whole message * or a fragment of a message to be reassembled. Messages are fragmented if greater than the frame for MTU in length. */ @FunctionalInterface public interface ControlledFragmentHandler { enum Action { /** * Abort the current polling operation and do not advance the position for this fragment. */ ABORT, /** * Break from the current polling operation and commit the position as of the end of the current fragment * being handled. */ BREAK, /** * Continue processing but commit the position as of the end of the current fragment so that * flow control is applied to this point. */ COMMIT, /** * Continue processing until fragment limit or no fragments with position commit at end of poll as the in * {@link FragmentHandler#onFragment(DirectBuffer, int, int, Header)}. */ CONTINUE, } /** * Callback for handling fragments of data being read from a log. * * @param buffer containing the data. * @param offset at which the data begins. * @param length of the data in bytes. * @param header representing the meta data for the data. * @return The action to be taken with regard to the stream position after the callback. */ Action onFragment(DirectBuffer buffer, int offset, int length, Header header); }