Return-Path: X-Original-To: apmail-commons-issues-archive@minotaur.apache.org Delivered-To: apmail-commons-issues-archive@minotaur.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id 2749E9D13 for ; Thu, 10 Nov 2011 19:45:13 +0000 (UTC) Received: (qmail 38886 invoked by uid 500); 10 Nov 2011 19:45:12 -0000 Delivered-To: apmail-commons-issues-archive@commons.apache.org Received: (qmail 38837 invoked by uid 500); 10 Nov 2011 19:45:12 -0000 Mailing-List: contact issues-help@commons.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: issues@commons.apache.org Delivered-To: mailing list issues@commons.apache.org Received: (qmail 38827 invoked by uid 99); 10 Nov 2011 19:45:12 -0000 Received: from athena.apache.org (HELO athena.apache.org) (140.211.11.136) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 10 Nov 2011 19:45:12 +0000 X-ASF-Spam-Status: No, hits=-2001.2 required=5.0 tests=ALL_TRUSTED,RP_MATCHES_RCVD X-Spam-Check-By: apache.org Received: from [140.211.11.116] (HELO hel.zones.apache.org) (140.211.11.116) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 10 Nov 2011 19:45:11 +0000 Received: from hel.zones.apache.org (hel.zones.apache.org [140.211.11.116]) by hel.zones.apache.org (Postfix) with ESMTP id 0523C4A203 for ; Thu, 10 Nov 2011 19:44:51 +0000 (UTC) Date: Thu, 10 Nov 2011 19:44:51 +0000 (UTC) From: "Sebb (Commented) (JIRA)" To: issues@commons.apache.org Message-ID: <968136282.18612.1320954291022.JavaMail.tomcat@hel.zones.apache.org> In-Reply-To: <1437856922.24418.1304595843118.JavaMail.tomcat@hel.zones.apache.org> Subject: [jira] [Commented] (IO-271) FileUtils.copyDirectory should be able to handle arbitrary number of files MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-JIRA-FingerPrint: 30527f35849b9dde25b450d4833f0394 [ https://issues.apache.org/jira/browse/IO-271?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13147959#comment-13147959 ] Sebb commented on IO-271: ------------------------- Yes, I think WontFix is appropriate. > FileUtils.copyDirectory should be able to handle arbitrary number of files > -------------------------------------------------------------------------- > > Key: IO-271 > URL: https://issues.apache.org/jira/browse/IO-271 > Project: Commons IO > Issue Type: Improvement > Components: Utilities > Affects Versions: 2.0.1 > Reporter: Stephen Kestle > Priority: Minor > > File.listFiles() uses up to a bit over 2 times as much memory as File.list(). The latter should be used in doCopyDirectory where there is no filter specified. > This memory usage is a problem when copying directories with hundreds of thousands of files. > I was also thinking of the option of implementing a file filter (that could be composed with the inputted filter) that would batch the file copy operation; copy the first 10000 (that match), then the next 10000 etc etc. > Because of the lack of ordering consistency (between runs) of File.listFiles(), there would need to be a final file filter that would accept files that have not successfully been copied. > I'm primarily concerned about copying into an empty directory (I validate this beforehand), but for general operation where it's a merge, the modification date re-writing should only be done in the final run of copies so that while batching occurs (and indeed the final "missed" filtering) files do not get copied if they have been modified after the start time. (I presume that I'm reading FileUtils correctly in that it overrides files...) -- This message is automatically generated by JIRA. If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa For more information on JIRA, see: http://www.atlassian.com/software/jira