<p dir="ltr">Java IO typically delegates to os (as most apps do) for most things. Which can cache io operations for some time and gives no guarantee of when operation is happening according to java doc. </p>
<p dir="ltr">For writes you can force the os by getting a file descriptor and calling sync on it. That forces the jvm to wait and calls a synchronous operation at os layer. Actually it forces the os to wait on the disk operation.i think the c equivalent is fsync but can't remember if that's exactly the same anymore. </p>
<p dir="ltr">The same mechanism probably applies to delete operations add they concern file descriptors and interaction with hard disk hardware. </p>
<p dir="ltr">Might not be the problem but that's the first thing is look at. </p>
<p dir="ltr">Chris<br>
</p>
<div class="gmail_quote">On 20 Feb 2014 22:44, "Martin Denham" <<a href="mailto:mjdenham@gmail.com">mjdenham@gmail.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div dir="ltr">I have been analyzing occasional And Bible module upgrade problems today.  DM - you observed this while attempting to upgrade KJV recently.<div><br></div><div>Upgrade consists of:</div><div>1. delete installed module (book.getDriver().delete(book);)</div>
<div>2. install new module</div><div><br></div><div>However about half the time an error occurs on step 2 in IOUtil.unpackZip on the following line:</div><div><div>     if (!parentDir.mkdirs()) {</div></div><div>This error never occurs when installing a new module so it is related to removal of the previous version of the module.</div>
<div><br></div><div>I can't really work out why that call sometimes fails during module upgrade and the only idea I have come up with is "Java is known not to delete files immediately, so mkdir may fail sometimes" (<a href="http://stackoverflow.com/questions/617414/create-a-temporary-directory-in-java" target="_blank">http://stackoverflow.com/questions/617414/create-a-temporary-directory-in-java</a>).  What do you think of that reason?  I have never knowingly observed this delay in deletion and the above is the only mention I have seen of this problem.</div>
<div><br></div><div>I have a sort-of work around for the above problem which is</div><div><div>1. remove module from JSword lists without deleting files (Books.installed().removeBook(book);)</div><div>2. install new module (overwriting previous files)</div>
</div><div>Do module file names ever change in later versions?  Are there any other potential problems?</div><div><br></div><div>There also seems to be a minor bug in Books.removeBook() which has;</div><div>     names.put(book.getName(), book);<br>
</div><div>which I believe should be:</div><div>     names.remove(book.getName());<br></div><div>but this does not appear to cause any problems.</div><div><br></div><div>Martin</div><div><br></div><div><br></div><div><br>
</div></div>
<br>_______________________________________________<br>
jsword-devel mailing list<br>
<a href="mailto:jsword-devel@crosswire.org">jsword-devel@crosswire.org</a><br>
<a href="http://www.crosswire.org/mailman/listinfo/jsword-devel" target="_blank">http://www.crosswire.org/mailman/listinfo/jsword-devel</a><br>
<br></blockquote></div>