netty5/transport/src/main/java/io/netty/channel/AbstractServerChannel.java
Trustin Lee 368156f5d0 Another round of the new API design
- Channel now creates a ChannelPipeline by itself

  I find no reason to allow a user to use one's own pipeline
  implementation since I saw nobody does except for the cases where a
  user wants to add a user attribute to a channel, which is now covered
  by AttributeMap.

- Removed ChannelEvent and its subtypes because they are replaced by
  direct method invocation.
- Replaced ChannelSink with Channel.unsafe()
- Various getter renaming (e.g. Channel.getId() -> Channel.id())
- Added ChannelHandlerInvoker interface
- Implemented AbstractChannel and AbstractServerChannel
- Some other changes I don't remember
2012-05-01 17:19:41 +09:00

97 lines
2.6 KiB
Java

/*
* Copyright 2011 The Netty Project
*
* The Netty Project 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.netty.channel;
import java.net.SocketAddress;
import java.util.AbstractQueue;
import java.util.Collections;
import java.util.Iterator;
/**
* A skeletal server-side {@link Channel} implementation. A server-side
* {@link Channel} does not allow the following operations:
* <ul>
* <li>{@link #connect(SocketAddress, ChannelFuture)}</li>
* <li>{@link #disconnect(ChannelFuture)}</li>
* <li>{@link #flush(ChannelFuture)}</li>
* <li>and the shortcut methods which calls the methods mentioned above
* </ul>
*/
public abstract class AbstractServerChannel extends AbstractChannel implements ServerChannel {
private final ChannelBufferHolder<Object> out = ChannelBufferHolders.messageBuffer(new NoopQueue());
/**
* Creates a new instance.
*/
protected AbstractServerChannel() {
super(null);
}
@Override
public ChannelBufferHolder<Object> out() {
return out;
}
@Override
public SocketAddress remoteAddress() {
return null;
}
@Override
protected void doConnect(SocketAddress remoteAddress, SocketAddress localAddress, ChannelFuture future) {
future.setFailure(new UnsupportedOperationException());
}
@Override
protected void doDisconnect(ChannelFuture future) {
future.setFailure(new UnsupportedOperationException());
}
@Override
protected int doFlush(ChannelFuture future) {
future.setFailure(new UnsupportedOperationException());
return 0;
}
private static class NoopQueue extends AbstractQueue<Object> {
@Override
public boolean offer(Object e) {
return false;
}
@Override
public Object poll() {
return null;
}
@Override
public Object peek() {
return null;
}
@Override
public Iterator<Object> iterator() {
return Collections.emptyList().iterator();
}
@Override
public int size() {
return 0;
}
}
}