[RFC][Icedtea-web]: Close streams after opening them.

Andrew Su asu at redhat.com
Mon Mar 7 16:04:43 PST 2011



----- Original Message -----
> From: "Omair Majid" <omajid at redhat.com>
> To: "Andrew Su" <asu at redhat.com>
> Cc: "Denis Lila" <dlila at redhat.com>, "IcedTea" <distro-pkg-dev at openjdk.java.net>
> Sent: Monday, March 7, 2011 6:56:40 PM
> Subject: Re: [RFC][Icedtea-web]: Close streams after opening them.
> On 03/07/2011 04:40 PM, Andrew Su wrote:
> >
> > ----- Original Message -----
> >> >  From: "Omair Majid"<omajid at redhat.com>
> >> >  To: "Andrew Su"<asu at redhat.com>
> >> >  Cc: "Denis Lila"<dlila at redhat.com>,
> >> >  "IcedTea"<distro-pkg-dev at openjdk.java.net>
> >> >  Sent: Monday, March 7, 2011 4:30:20 PM
> >> >  Subject: Re: [RFC][Icedtea-web]: Close streams after opening
> >> >  them.
> >> >  On 03/07/2011 04:01 PM, Andrew Su wrote:
> >>>> >  >>  Subject: Re: [RFC][Icedtea-web]: Close streams after
> >>>> >  >>  opening them.
> >>>>> >  >>>  Questions, comments, concerns?
> >>>> >  >>
> >>>> >  >>  Maybe it would be better to put the close() in a "finally"
> >>>> >  >>  block
> >>>> >  >>  after the catch?
> >>> >  >
> >>> >  >  I don't think that'd be necessary, since if an exception was
> >>> >  >  thrown.
> >>> >  >  The stream won't be open.
> >>> >  >
> >> >
> >> >  store(s, header) can throw an IOException too. I agree with
> >> >  Dennis;
> >> >  s.close() should be in a finally block. I also see similar code
> >> >  in
> >> >  PropertiesFile.load(): an InputStream is never closed. Can you
> >> >  please
> >> >  fix that too?
> > Haha yeah, I overlooked that. :P
> > Updated to fix this for load() as well.
> >
> > Cheers,
> >   Andrew
> >
> >> >
> >> >  Cheers,
> >> >  Omair
> >
> >
> > 20110307_close_streams_v3.patch
> >
> >
> > diff -r 5bc80c9e11c7
> > netx/net/sourceforge/jnlp/util/PropertiesFile.java
> > --- a/netx/net/sourceforge/jnlp/util/PropertiesFile.java Mon Mar 07
> > 09:50:14 2011 -0500
> > +++ b/netx/net/sourceforge/jnlp/util/PropertiesFile.java Mon Mar 07
> > 16:40:28 2011 -0500
> > @@ -109,15 +109,21 @@
> >        */
> >       public void load() {
> >           loaded = true;
> > -
> > +
> 
> Please dont include unnecessary whitespace changes.

*blames IDE*

> 
> > + InputStream s = null;
> >           try {
> >               if (!file.exists())
> >                   return;
> >
> > - InputStream s = new FileInputStream(file);
> > + s = new FileInputStream(file);
> >               load(s);
> >           } catch (IOException ex) {
> >               // eat
> > + } finally {
> > + try {
> > + s.close();
> > + } catch (Exception e) {
> > + }
> 
> Please only catch IOException. I dont think we should completely
> swallow
> exceptions. A printStackTrace would be better. I am quite surprised
> the
> original code is fine with eating exceptions too..
Fixed.
Here's the updated patch.

Okay to commit after adding ChangeLog?

Cheers,
  Andrew

> 
> >           }
> >       }
> >
> > @@ -127,13 +133,18 @@
> >       public void store() {
> >           if (!loaded)
> >               return; // nothing could have changed so save
> >               unnecessary load/save
> > -
> > +
> > + OutputStream s = null;
> >           try {
> > - OutputStream s = new FileOutputStream(file);
> > + s = new FileOutputStream(file);
> >               store(s, header);
> >           } catch (IOException ex) {
> >               // eat
> > + } finally {
> > + try {
> > + s.close();
> > + } catch (Exception e) {
> > + }
> >           }
> >       }
> > -
> >   }
> 
> Same concerns here.
> 
> Cheers,
> Omair
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 20110307_close_streams_v4.patch
Type: text/x-patch
Size: 1254 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20110307/af3854e6/20110307_close_streams_v4.patch 


More information about the distro-pkg-dev mailing list