diff options
| author | das <das> | 2005-12-05 13:03:16 (GMT) | 
|---|---|---|
| committer | das <das> | 2005-12-05 13:03:16 (GMT) | 
| commit | 73355c6aa96b891582ca0932fe2a459c703bc8fe (patch) | |
| tree | de184beb12392b5d5382cd6ff21227041743df82 /unix/tclUnixFCmd.c | |
| parent | e55c5a7902ccc8af5a6e3fb14bc9795d17235ede (diff) | |
| download | tcl-73355c6aa96b891582ca0932fe2a459c703bc8fe.zip tcl-73355c6aa96b891582ca0932fe2a459c703bc8fe.tar.gz tcl-73355c6aa96b891582ca0932fe2a459c703bc8fe.tar.bz2 | |
	* unix/configure.in: move check for fts API to configure.in and run it
	* unix/tcl.m4:       on all platforms, since Linux glibc2 and *BSDs also
	have this; using fts is more efficient than recursive opendir/readdir.
	* unix/tclUnixFCmd.c (TraverseUnixTree): add support to fts code for
	platforms with stat64.
	* unix/configure:
	* unix/tclConfig.h.in: regen.
Diffstat (limited to 'unix/tclUnixFCmd.c')
| -rw-r--r-- | unix/tclUnixFCmd.c | 35 | 
1 files changed, 23 insertions, 12 deletions
| diff --git a/unix/tclUnixFCmd.c b/unix/tclUnixFCmd.c index bdb4cef..e32c467 100644 --- a/unix/tclUnixFCmd.c +++ b/unix/tclUnixFCmd.c @@ -10,7 +10,7 @@   * See the file "license.terms" for information on usage and redistribution of   * this file, and for a DISCLAIMER OF ALL WARRANTIES.   * - * RCS: @(#) $Id: tclUnixFCmd.c,v 1.50 2005/12/05 08:19:37 hobbs Exp $ + * RCS: @(#) $Id: tclUnixFCmd.c,v 1.51 2005/12/05 13:03:18 das Exp $   *   * Portions of this code were derived from NetBSD source code which has the   * following copyright notice: @@ -992,18 +992,15 @@ TraverseUnixTree(  	result = (*traverseProc)(sourcePtr, targetPtr, &statBuf, DOTREE_POSTD,  		errorPtr);      } - -  end: -    if (errfile != NULL) { -	if (errorPtr != NULL) { -	    Tcl_ExternalToUtfDString(NULL, errfile, -1, errorPtr); -	} -	result = TCL_ERROR; -    }  #else /* HAVE_FTS */      paths[0] = source;      fts = fts_open((char**)paths, FTS_PHYSICAL|FTS_NOCHDIR| -	    (doRewind ? FTS_NOSTAT : 0), NULL); /* no need to stat for delete */ +#ifdef HAVE_STRUCT_STAT64 +	    FTS_NOSTAT,				/* fts doesn't do stat64 */ +#else +	    (doRewind ? FTS_NOSTAT : 0),	/* no need to stat for delete */ +#endif +	    NULL);      if (fts == NULL) {  	errfile = source;  	goto end; @@ -1019,6 +1016,7 @@ TraverseUnixTree(  	char * path = ent->fts_path + sourceLen;  	unsigned short pathlen = ent->fts_pathlen - sourceLen;  	int type; +	Tcl_StatBuf *statBufPtr = NULL;  	if (info == FTS_DNR || info == FTS_ERR || info == FTS_NS) {  	    errfile = ent->fts_path; @@ -1039,7 +1037,18 @@ TraverseUnixTree(  		type = DOTREE_F;  		break;  	} -	result = (*traverseProc)(sourcePtr, targetPtr, ent->fts_statp, type, +	if (!doRewind) { /* no need to stat for delete */ +#ifdef HAVE_STRUCT_STAT64 +	    statBufPtr = &statBuf; +	    if (TclOSlstat(ent->fts_path, statBufPtr) != 0) { +		errfile = ent->fts_path; +		break; +	    } +#else +	    statBufPtr = ent->fts_statp; +#endif +	} +	result = (*traverseProc)(sourcePtr, targetPtr, statBufPtr, type,  		errorPtr);  	if (result != TCL_OK) {  	    break; @@ -1049,6 +1058,7 @@ TraverseUnixTree(  	    Tcl_DStringSetLength(targetPtr, targetLen);  	}      } +#endif /* HAVE_FTS */    end:      if (errfile != NULL) { @@ -1057,10 +1067,11 @@ TraverseUnixTree(  	}  	result = TCL_ERROR;      } +#ifdef HAVE_FTS      if (fts != NULL) {  	fts_close(fts);      } -#endif /* HAVE_FTS */ +#endif      return result;  } | 
