netty5/src/main/java/net/gleamynode/netty/handler/codec/serialization/CompatibleObjectEncoder.java

93 lines
3.2 KiB
Java
Raw Normal View History

/*
* Copyright (C) 2008 Trustin Heuiseung Lee
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, 5th Floor, Boston, MA 02110-1301 USA
*/
package net.gleamynode.netty.handler.codec.serialization;
import static net.gleamynode.netty.buffer.ChannelBuffers.*;
import static net.gleamynode.netty.channel.Channels.*;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import net.gleamynode.netty.buffer.ChannelBuffer;
import net.gleamynode.netty.buffer.ChannelBufferOutputStream;
import net.gleamynode.netty.channel.ChannelDownstreamHandler;
import net.gleamynode.netty.channel.ChannelEvent;
import net.gleamynode.netty.channel.ChannelHandlerContext;
import net.gleamynode.netty.channel.ChannelPipelineCoverage;
import net.gleamynode.netty.channel.MessageEvent;
/**
* @author The Netty Project (netty@googlegroups.com)
* @author Trustin Lee (trustin@gmail.com)
*
* @version $Rev:231 $, $Date:2008-06-12 16:44:50 +0900 (, 12 6월 2008) $
*
*/
@ChannelPipelineCoverage("all")
public class CompatibleObjectEncoder implements ChannelDownstreamHandler {
private final ChannelBuffer buffer = dynamicBuffer();
private final int resetInterval;
private volatile ObjectOutputStream oout;
private int writtenObjects;
public CompatibleObjectEncoder() {
this(16); // Reset at every sixteen writes
}
public CompatibleObjectEncoder(int resetInterval) {
if (resetInterval < 0) {
throw new IllegalArgumentException(
"resetInterval: " + resetInterval);
}
this.resetInterval = resetInterval;
}
public void handleDownstream(
ChannelHandlerContext context, ChannelEvent evt) throws Exception {
if (!(evt instanceof MessageEvent)) {
context.sendDownstream(evt);
return;
}
MessageEvent e = (MessageEvent) evt;
buffer.clear();
if (oout == null) {
oout = newObjectOutputStream(new ChannelBufferOutputStream(buffer));
}
if (resetInterval != 0) {
// Resetting will prevent OOM on the receiving side.
writtenObjects ++;
if (writtenObjects % resetInterval == 0) {
oout.reset();
}
}
oout.writeObject(e.getMessage());
oout.flush();
ChannelBuffer encoded = buffer.readBytes(buffer.readableBytes());
write(context, e.getChannel(), e.getFuture(), encoded, e.getRemoteAddress());
}
protected ObjectOutputStream newObjectOutputStream(OutputStream out) throws Exception {
return new ObjectOutputStream(out);
}
}