stleary / JSON-java

A reference implementation of a JSON package in Java.
http://stleary.github.io/JSON-java/index.html
Other
4.54k stars 2.56k forks source link

org.json.JSONTokener should close or provide option to close java.io.Reader #836

Open rikkarth opened 11 months ago

rikkarth commented 11 months ago

Hi,

I spent a few days trying to fix an issue where I got the following error:

java.nio.file.FileSystemException: path/to/file: The process cannot access the file because it is being used by another process.

I started using FileLock to try to get a hold on the lock and wait until the lock was released, but unfortunately for this file, it would never be released.

That is because I was using a JSONTokener to tokenize a JSON file using an anonymous FileReader. This stream would never be closed, and therefor the error mentioned above.

image

Because JSONTokener doesn't provide an API to close the stream provided as parameter, I have to correct my implementation like this:

image

Obviously after reading the class it is clear how it should be used, since it is clearly written in the JavaDoc that the Reader must be closed by the caller.

image

I believe this implementation could be improved.

image

Let me know if my suggestion is outrageous. But I feel at least I should bring it here.

Thank you for your attention. :)

stleary commented 11 months ago

@rikkarth Thanks for bringing this up. Unfortunately, at present, this project cannot accept Java 8 features like Closeable and AutoCloseable due to some Android developers being stuck on Java 7.

rikkarth commented 11 months ago

@stleary , thank you for the quick reply.

Not sure if is worth to keep or archive this ticket for the future then. But thank you for your attention to this.

Thank you for the feedback and have a great day.

rikkarth commented 10 months ago

hi, since new version supports Closeable and AutoCloseable, I'd like just to suggest that the JSONTokener to be reviewed if possible. Thank you for your service.

stleary commented 9 months ago

Hi @rikkarth Sorry, that is still not an option at this time.