tisdag 17 mars 2009 02:16:09 skrev "Shawn O. Pearce" <spearce@xxxxxxxxxxx>: > If we detect a file open failure while opening a pack we halve > the number of permitted open files and try again, until we reach > a lower bound of 16 open files. Needing to go lower may indicate > a file descriptor leak in the host application. ... > + TRY_OPEN: for (;;) { > + try { > + openFileCount++; > + releaseMemory(); > + runClearedWindowQueue(); > + wp.openCount = 1; > + wp.cacheOpen(); > + break; > + } catch (IOException ioe) { > + openFileCount--; > + if ("Too many open files".equals(ioe.getMessage()) > + && maxFileCount > 16) { The output of getMessage isn't that simple to interpret. Here it is filename+" (Too many files open)", and on other platforms it is probably something else. This goes for the message part of most exceptions thrown from platform specific code like file i/o socket i/o etc. The type of exception is a FileNotFoundException, btw. I wonder whether your code works on any platform. -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html