
org.glassfish.grizzly.nio.transport.TCPNIOAsyncQueueReader Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2008, 2020 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package org.glassfish.grizzly.nio.transport;
import java.io.IOException;
import java.net.SocketAddress;
import org.glassfish.grizzly.Buffer;
import org.glassfish.grizzly.CompletionHandler;
import org.glassfish.grizzly.Connection;
import org.glassfish.grizzly.IOEvent;
import org.glassfish.grizzly.Interceptor;
import org.glassfish.grizzly.ReadResult;
import org.glassfish.grizzly.asyncqueue.AsyncQueueReader;
import org.glassfish.grizzly.asyncqueue.AsyncReadQueueRecord;
import org.glassfish.grizzly.nio.AbstractNIOAsyncQueueReader;
import org.glassfish.grizzly.nio.NIOConnection;
import org.glassfish.grizzly.nio.NIOTransport;
/**
* The TCP transport {@link AsyncQueueReader} implementation, based on the Java NIO
*
* @author Alexey Stashok
*/
public final class TCPNIOAsyncQueueReader extends AbstractNIOAsyncQueueReader {
public TCPNIOAsyncQueueReader(NIOTransport transport) {
super(transport);
}
@Override
protected int read0(final Connection connection, Buffer buffer, final ReadResult currentResult) throws IOException {
final int oldPosition = buffer != null ? buffer.position() : 0;
if ((buffer = ((TCPNIOTransport) transport).read(connection, buffer)) != null) {
final int readBytes = buffer.position() - oldPosition;
currentResult.setMessage(buffer);
currentResult.setReadSize(currentResult.getReadSize() + readBytes);
currentResult.setSrcAddressHolder(((TCPNIOConnection) connection).peerSocketAddressHolder);
return readBytes;
}
return 0;
}
protected void addRecord(Connection connection, Buffer buffer, CompletionHandler completionHandler, Interceptor interceptor) {
final AsyncReadQueueRecord record = AsyncReadQueueRecord.create(connection, buffer, completionHandler, interceptor);
((TCPNIOConnection) connection).getAsyncReadQueue().offer(record);
}
@Override
protected void onReadyToRead(Connection connection) throws IOException {
final NIOConnection nioConnection = (NIOConnection) connection;
nioConnection.enableIOEvent(IOEvent.READ);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy