Go to file
Norman Maurer 15162202fb [#4435] Always invoke the actual deregisteration later in the EventLoop.
Motivation:

As a user may call deregister() from within any method while doing processing in the ChannelPipeline,  we need to ensure we do the actual deregister operation later. This is needed as for example,  we may be in the ByteToMessageDecoder.callDecode(...) method and so still try to do processing in the old EventLoop while the user already registered the Channel to a new EventLoop. Without delay, the deregister operation this could lead to have a handler invoked by different EventLoop and so threads.

Modifications:

Ensure the actual deregister will be done later on and not directly when invoked.

Result:

Calling deregister() within ByteToMessageDecoder.decode(..) is safe.
2015-12-24 14:19:47 +01:00
all Fix version 2015-11-24 21:24:22 +01:00
buffer ByteBufUtil.writeUtf8 Surrogate Support 2015-12-18 13:56:05 -08:00
codec Not use Unpooled to allocate buffers in Base64 but use a ByteBufAllocator 2015-12-18 21:22:47 +01:00
codec-haproxy Fix version 2015-11-24 21:24:22 +01:00
codec-http [#4505] Correctly handle whitespaces in websocket uri's. 2015-12-10 13:52:28 +01:00
codec-socks Fix version 2015-11-24 21:24:22 +01:00
common Builder to construct DomainNameMapping. 2015-12-20 18:57:49 +01:00
example Fix version 2015-11-24 21:24:22 +01:00
handler Close FileInputStream after consuming it in SelfSignedCertificate 2015-12-24 07:51:37 +01:00
license Let PoolThreadCache work even if allocation and deallocation Thread are different 2015-05-27 14:35:22 +02:00
microbench Fix version 2015-11-24 21:24:22 +01:00
tarball Fix version 2015-11-24 21:24:22 +01:00
testsuite Fix version 2015-11-24 21:24:22 +01:00
testsuite-osgi Fix version 2015-11-24 21:24:22 +01:00
transport [#4435] Always invoke the actual deregisteration later in the EventLoop. 2015-12-24 14:19:47 +01:00
transport-native-epoll Ensure closing a Socket / FileDescriptor multiple times will not throw exception 2015-12-23 23:04:44 +01:00
transport-rxtx Fix version 2015-11-24 21:24:22 +01:00
transport-sctp Clear selectedKeys in OioSctpChannel.doReadMessages 2015-12-21 09:59:33 +01:00
transport-udt Fix version 2015-11-24 21:24:22 +01:00
.fbprefs Updated Find Bugs configuration 2009-03-04 10:33:09 +00:00
.gitignore Add JVM crash logs to .gitignore 2014-05-18 21:37:12 +09:00
.travis.yml Travis CI branch whitelisting 2013-03-11 09:55:43 +09:00
CONTRIBUTING.md Move the pull request guide to the developer guide 2014-03-12 13:18:14 +09:00
LICENSE.txt Relicensed to Apache License v2 2009-08-28 07:15:49 +00:00
NOTICE.txt Let PoolThreadCache work even if allocation and deallocation Thread are different 2015-05-27 14:35:22 +02:00
pom.xml Fix version 2015-11-24 21:24:22 +01:00
README.md Fix the 'branches to look' section 2015-10-27 13:58:06 +01:00
run-example.sh Add logLevel property to enable different log levels for the examples. 2014-11-21 10:48:13 +09:00

Netty Project

Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients.

How to build

For the detailed information about building and developing Netty, please visit the developer guide. This page only gives very basic information.

You require the following to build Netty:

Note that this is build-time requirement. JDK 5 (for 3.x) or 6 (for 4.0+) is enough to run your Netty-based application.

Branches to look

The 'master' branch is where the development of the latest major version lives on. The development of all other versions takes place in each branch whose name is identical to <majorVersion>.<minorVersion>. For example, the development of 3.9 and 4.0 resides in the branch '3.9' and the branch '4.0' respectively.