From 15d4787724ad8723d36e771a9709db51933df2c1 Mon Sep 17 00:00:00 2001 From: Hamlin Li Date: Tue, 27 Apr 2021 01:06:56 +0000 Subject: [PATCH] 8265496: improve null check in DeflaterOutputStream/InflaterInputStream Reviewed-by: lancea, naoto --- .../share/classes/java/util/zip/DeflaterInputStream.java | 4 ++-- .../share/classes/java/util/zip/DeflaterOutputStream.java | 4 ++-- .../share/classes/java/util/zip/GZIPInputStream.java | 4 ++-- .../share/classes/java/util/zip/GZIPOutputStream.java | 4 ++-- .../share/classes/java/util/zip/InflaterInputStream.java | 4 ++-- .../share/classes/java/util/zip/InflaterOutputStream.java | 4 ++-- .../share/classes/java/util/zip/ZipOutputStream.java | 4 ++-- .../micro/org/openjdk/bench/java/io/DataOutputStreamTest.java | 2 +- 8 files changed, 15 insertions(+), 15 deletions(-) diff --git a/src/java.base/share/classes/java/util/zip/DeflaterInputStream.java b/src/java.base/share/classes/java/util/zip/DeflaterInputStream.java index d1ab13d505b..e0ecba0fcad 100644 --- a/src/java.base/share/classes/java/util/zip/DeflaterInputStream.java +++ b/src/java.base/share/classes/java/util/zip/DeflaterInputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -74,7 +74,7 @@ public class DeflaterInputStream extends FilterInputStream { * @throws NullPointerException if {@code in} is null */ public DeflaterInputStream(InputStream in) { - this(in, new Deflater()); + this(in, in != null ? new Deflater() : null); usesDefaultDeflater = true; } diff --git a/src/java.base/share/classes/java/util/zip/DeflaterOutputStream.java b/src/java.base/share/classes/java/util/zip/DeflaterOutputStream.java index 7ef07084615..365bc676b08 100644 --- a/src/java.base/share/classes/java/util/zip/DeflaterOutputStream.java +++ b/src/java.base/share/classes/java/util/zip/DeflaterOutputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -158,7 +158,7 @@ public class DeflaterOutputStream extends FilterOutputStream { * @since 1.7 */ public DeflaterOutputStream(OutputStream out, boolean syncFlush) { - this(out, new Deflater(), 512, syncFlush); + this(out, out != null ? new Deflater() : null, 512, syncFlush); usesDefaultDeflater = true; } diff --git a/src/java.base/share/classes/java/util/zip/GZIPInputStream.java b/src/java.base/share/classes/java/util/zip/GZIPInputStream.java index 92211ee31be..613a02bbad0 100644 --- a/src/java.base/share/classes/java/util/zip/GZIPInputStream.java +++ b/src/java.base/share/classes/java/util/zip/GZIPInputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -74,7 +74,7 @@ public class GZIPInputStream extends InflaterInputStream { * @throws IllegalArgumentException if {@code size <= 0} */ public GZIPInputStream(InputStream in, int size) throws IOException { - super(in, new Inflater(true), size); + super(in, in != null ? new Inflater(true) : null, size); usesDefaultInflater = true; readHeader(in); } diff --git a/src/java.base/share/classes/java/util/zip/GZIPOutputStream.java b/src/java.base/share/classes/java/util/zip/GZIPOutputStream.java index db61ee2da23..153af0959b1 100644 --- a/src/java.base/share/classes/java/util/zip/GZIPOutputStream.java +++ b/src/java.base/share/classes/java/util/zip/GZIPOutputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -90,7 +90,7 @@ public class GZIPOutputStream extends DeflaterOutputStream { public GZIPOutputStream(OutputStream out, int size, boolean syncFlush) throws IOException { - super(out, new Deflater(Deflater.DEFAULT_COMPRESSION, true), + super(out, out != null ? new Deflater(Deflater.DEFAULT_COMPRESSION, true) : null, size, syncFlush); usesDefaultDeflater = true; diff --git a/src/java.base/share/classes/java/util/zip/InflaterInputStream.java b/src/java.base/share/classes/java/util/zip/InflaterInputStream.java index 666de6ab983..534241d3d0a 100644 --- a/src/java.base/share/classes/java/util/zip/InflaterInputStream.java +++ b/src/java.base/share/classes/java/util/zip/InflaterInputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -105,7 +105,7 @@ public class InflaterInputStream extends FilterInputStream { * @param in the input stream */ public InflaterInputStream(InputStream in) { - this(in, new Inflater()); + this(in, in != null ? new Inflater() : null); usesDefaultInflater = true; } diff --git a/src/java.base/share/classes/java/util/zip/InflaterOutputStream.java b/src/java.base/share/classes/java/util/zip/InflaterOutputStream.java index ebeaaac540d..aa306239224 100644 --- a/src/java.base/share/classes/java/util/zip/InflaterOutputStream.java +++ b/src/java.base/share/classes/java/util/zip/InflaterOutputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -74,7 +74,7 @@ public class InflaterOutputStream extends FilterOutputStream { * @throws NullPointerException if {@code out} is null */ public InflaterOutputStream(OutputStream out) { - this(out, new Inflater()); + this(out, out != null ? new Inflater() : null); usesDefaultInflater = true; } diff --git a/src/java.base/share/classes/java/util/zip/ZipOutputStream.java b/src/java.base/share/classes/java/util/zip/ZipOutputStream.java index e8e20da17cf..e70aacb8266 100644 --- a/src/java.base/share/classes/java/util/zip/ZipOutputStream.java +++ b/src/java.base/share/classes/java/util/zip/ZipOutputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -130,7 +130,7 @@ public class ZipOutputStream extends DeflaterOutputStream implements ZipConstant * @since 1.7 */ public ZipOutputStream(OutputStream out, Charset charset) { - super(out, new Deflater(Deflater.DEFAULT_COMPRESSION, true)); + super(out, out != null ? new Deflater(Deflater.DEFAULT_COMPRESSION, true) : null); if (charset == null) throw new NullPointerException("charset is null"); this.zc = ZipCoder.get(charset); diff --git a/test/micro/org/openjdk/bench/java/io/DataOutputStreamTest.java b/test/micro/org/openjdk/bench/java/io/DataOutputStreamTest.java index a6ebac635b2..ec682978bc2 100644 --- a/test/micro/org/openjdk/bench/java/io/DataOutputStreamTest.java +++ b/test/micro/org/openjdk/bench/java/io/DataOutputStreamTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2020, Red Hat Inc. All rights reserved. + * Copyright (c) 2020, 2021, Red Hat Inc. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it