From: Robert Griebl Date: Wed, 24 Jul 2002 00:34:48 +0000 (-0000) Subject: Patch for bug #1183: Added a -xdev option to find (configurable) X-Git-Tag: 0_60_4~111 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=41369af3f2bd415c58266618aa3fd1fe6badacfa;p=platform%2Fupstream%2Fbusybox.git Patch for bug #1183: Added a -xdev option to find (configurable) --- diff --git a/findutils/config.in b/findutils/config.in index 770d752..d5a3714 100644 --- a/findutils/config.in +++ b/findutils/config.in @@ -11,6 +11,7 @@ if [ "$CONFIG_FIND" = "y" ] ; then bool ' Enable modified time matching (-mtime) option' CONFIG_FEATURE_FIND_MTIME bool ' Enable permissions matching (-perm) option' CONFIG_FEATURE_FIND_PERM bool ' Enable filetype matching (-type) option' CONFIG_FEATURE_FIND_TYPE + bool ' Enable stay in filesystem (-xdev) option' CONFIG_FEATURE_FIND_XDEV fi bool 'grep' CONFIG_GREP if [ "$CONFIG_GREP" = "y" ] ; then diff --git a/findutils/find.c b/findutils/find.c index 0ff0893..dd02206 100644 --- a/findutils/find.c +++ b/findutils/find.c @@ -51,6 +51,12 @@ static char mtime_char; static int mtime_days; #endif +#ifdef CONFIG_FEATURE_FIND_XDEV +static dev_t *xdev_dev; +static int xdev_count = 0; +#endif + + static int fileAction(const char *fileName, struct stat *statbuf, void* junk) { if (pattern != NULL) { @@ -88,6 +94,22 @@ static int fileAction(const char *fileName, struct stat *statbuf, void* junk) goto no_match; } #endif +#ifdef CONFIG_FEATURE_FIND_XDEV + if (xdev_count) { + int i; + for (i=0; i st_dev) + break; + } + if (i == xdev_count) { + if(S_ISDIR(statbuf->st_mode)) + return SKIP; + else + goto no_match; + } + } +#endif + puts(fileName); no_match: return (TRUE); @@ -180,6 +202,27 @@ int find_main(int argc, char **argv) if ((mtime_char = argv[i][0]) == '-') mtime_days = -mtime_days; #endif +#ifdef CONFIG_FEATURE_FIND_XDEV + } else if (strcmp(argv[i], "-xdev") == 0) { + struct stat stbuf; + + xdev_count = ( firstopt - 1 ) ? ( firstopt - 1 ) : 1; + xdev_dev = xmalloc ( xdev_count * sizeof( dev_t )); + + if ( firstopt == 1 ) { + if ( stat ( ".", &stbuf ) < 0 ) + error_msg_and_die("could not stat '.'" ); + xdev_dev [0] = stbuf. st_dev; + } + else { + + for (i = 1; i < firstopt; i++) { + if ( stat ( argv [i], &stbuf ) < 0 ) + error_msg_and_die("could not stat '%s'", argv [i] ); + xdev_dev [i-1] = stbuf. st_dev; + } + } +#endif } else show_usage(); }