Add io.netty.noJdkZlibEncoder system property

Related issue: #2821

Motivation:

There's no way for a user to change the default ZlibEncoder
implementation.

It is already possible to change the default ZlibDecoder implementation.

Modification:

Add a new system property 'io.netty.noJdkZlibEncoder'.

Result:

A user can disable JDK ZlibEncoder, just like he or she can disable JDK
ZlibDecoder.
This commit is contained in:
Trustin Lee 2014-08-26 15:46:11 +09:00
parent 892944eba8
commit 239371abaf

View File

@ -30,14 +30,18 @@ public final class ZlibCodecFactory {
private static final int DEFAULT_JDK_MEM_LEVEL = 8; private static final int DEFAULT_JDK_MEM_LEVEL = 8;
private static final boolean noJdkZlibDecoder; private static final boolean noJdkZlibDecoder;
private static final boolean noJdkZlibEncoder;
static { static {
noJdkZlibDecoder = SystemPropertyUtil.getBoolean("io.netty.noJdkZlibDecoder", true); noJdkZlibDecoder = SystemPropertyUtil.getBoolean("io.netty.noJdkZlibDecoder", true);
logger.debug("-Dio.netty.noJdkZlibDecoder: {}", noJdkZlibDecoder); logger.debug("-Dio.netty.noJdkZlibDecoder: {}", noJdkZlibDecoder);
noJdkZlibEncoder = SystemPropertyUtil.getBoolean("io.netty.noJdkZlibEncoder", false);
logger.debug("-Dio.netty.noJdkZlibEncoder: {}", noJdkZlibEncoder);
} }
public static ZlibEncoder newZlibEncoder(int compressionLevel) { public static ZlibEncoder newZlibEncoder(int compressionLevel) {
if (PlatformDependent.javaVersion() < 7) { if (PlatformDependent.javaVersion() < 7 || noJdkZlibEncoder) {
return new JZlibEncoder(compressionLevel); return new JZlibEncoder(compressionLevel);
} else { } else {
return new JdkZlibEncoder(compressionLevel); return new JdkZlibEncoder(compressionLevel);
@ -45,7 +49,7 @@ public final class ZlibCodecFactory {
} }
public static ZlibEncoder newZlibEncoder(ZlibWrapper wrapper) { public static ZlibEncoder newZlibEncoder(ZlibWrapper wrapper) {
if (PlatformDependent.javaVersion() < 7) { if (PlatformDependent.javaVersion() < 7 || noJdkZlibEncoder) {
return new JZlibEncoder(wrapper); return new JZlibEncoder(wrapper);
} else { } else {
return new JdkZlibEncoder(wrapper); return new JdkZlibEncoder(wrapper);
@ -53,7 +57,7 @@ public final class ZlibCodecFactory {
} }
public static ZlibEncoder newZlibEncoder(ZlibWrapper wrapper, int compressionLevel) { public static ZlibEncoder newZlibEncoder(ZlibWrapper wrapper, int compressionLevel) {
if (PlatformDependent.javaVersion() < 7) { if (PlatformDependent.javaVersion() < 7 || noJdkZlibEncoder) {
return new JZlibEncoder(wrapper, compressionLevel); return new JZlibEncoder(wrapper, compressionLevel);
} else { } else {
return new JdkZlibEncoder(wrapper, compressionLevel); return new JdkZlibEncoder(wrapper, compressionLevel);
@ -61,7 +65,7 @@ public final class ZlibCodecFactory {
} }
public static ZlibEncoder newZlibEncoder(ZlibWrapper wrapper, int compressionLevel, int windowBits, int memLevel) { public static ZlibEncoder newZlibEncoder(ZlibWrapper wrapper, int compressionLevel, int windowBits, int memLevel) {
if (PlatformDependent.javaVersion() < 7 || if (PlatformDependent.javaVersion() < 7 || noJdkZlibEncoder ||
windowBits != DEFAULT_JDK_WINDOW_SIZE || memLevel != DEFAULT_JDK_MEM_LEVEL) { windowBits != DEFAULT_JDK_WINDOW_SIZE || memLevel != DEFAULT_JDK_MEM_LEVEL) {
return new JZlibEncoder(wrapper, compressionLevel, windowBits, memLevel); return new JZlibEncoder(wrapper, compressionLevel, windowBits, memLevel);
} else { } else {
@ -70,7 +74,7 @@ public final class ZlibCodecFactory {
} }
public static ZlibEncoder newZlibEncoder(byte[] dictionary) { public static ZlibEncoder newZlibEncoder(byte[] dictionary) {
if (PlatformDependent.javaVersion() < 7) { if (PlatformDependent.javaVersion() < 7 || noJdkZlibEncoder) {
return new JZlibEncoder(dictionary); return new JZlibEncoder(dictionary);
} else { } else {
return new JdkZlibEncoder(dictionary); return new JdkZlibEncoder(dictionary);
@ -78,7 +82,7 @@ public final class ZlibCodecFactory {
} }
public static ZlibEncoder newZlibEncoder(int compressionLevel, byte[] dictionary) { public static ZlibEncoder newZlibEncoder(int compressionLevel, byte[] dictionary) {
if (PlatformDependent.javaVersion() < 7) { if (PlatformDependent.javaVersion() < 7 || noJdkZlibEncoder) {
return new JZlibEncoder(compressionLevel, dictionary); return new JZlibEncoder(compressionLevel, dictionary);
} else { } else {
return new JdkZlibEncoder(compressionLevel, dictionary); return new JdkZlibEncoder(compressionLevel, dictionary);
@ -87,7 +91,8 @@ public final class ZlibCodecFactory {
public static ZlibEncoder newZlibEncoder(int compressionLevel, int windowBits, int memLevel, byte[] dictionary) { public static ZlibEncoder newZlibEncoder(int compressionLevel, int windowBits, int memLevel, byte[] dictionary) {
if (PlatformDependent.javaVersion() < 7 || if (PlatformDependent.javaVersion() < 7 ||
windowBits != DEFAULT_JDK_WINDOW_SIZE || memLevel != DEFAULT_JDK_MEM_LEVEL) { windowBits != DEFAULT_JDK_WINDOW_SIZE || memLevel != DEFAULT_JDK_MEM_LEVEL ||
noJdkZlibEncoder) {
return new JZlibEncoder(compressionLevel, windowBits, memLevel, dictionary); return new JZlibEncoder(compressionLevel, windowBits, memLevel, dictionary);
} else { } else {
return new JdkZlibEncoder(compressionLevel, dictionary); return new JdkZlibEncoder(compressionLevel, dictionary);