Thanks, this helps a lot. What I'm looking to "remove" is my temp directory 
where I'm downloading files un-compressing them etc. Just good house keeping.  

I must admit having not been doing this long, and after Kyle's remark on 
"collected consulting fees" I'm surprised that there isn't a task as part of 
NSFileManager to remove items recursively like 
"removeItemAtPath:recursive:error:" for example. I mean Mac OS X is over 10 
years old. :-)

Thanks,
tom 




On Aug 14, 2010, at 8:02 AM, Jerry Krinock wrote:

> As noted, your choices are either NSFileManager methods of BSD/POSIX 
> functions.  I would tend to start with the latter because, at the end of the 
> week, NSFileManager might not have the configurability you need to handle the 
> nitty-gritty like system "dot" or "dot dot" files, (not) following symbolic 
> links, etc. etc.  But it may be just a personal preference.  NSFileManager 
> has not always been my friend.
> 
> If you go the BSD route, also consider fts_open(), fts_read(), fts_close() 
> since these handle the recursion for you.  A few weeks ago I wrote a 
> demo/template using these which is pasted in below.  Because fts_read returns 
> directories first followed by their descendants, you'd need to create an 
> array and then "remove" items in reverse order, using appropriate functions 
> for regular files vs. directories.
> 
> And as Don Quixote implied, you need to think about exactly what you mean by 
> "remove".
> 
> 
> #include <fts.h>
> 
> int doSomething(char * const path) {
>    printf("Doing %s\n", path) ;
>    return 0 ;
> }
> 
> int doSomething_recursive(char * const path) {
>    // See man fts(3) for these.  Modify these to do what you want:
>    int fts_options =  FTS_PHYSICAL | FTS_NOCHDIR | FTS_XDEV | FTS_SEEDOT ;
> 
>    // fts_open requires a null-terminated array of paths.
>    // We only have one path.
>    char* paths[2] ;
>    paths[0] = path ;
>    paths[1] = NULL ;
> 
>    FTS* ftsp = fts_open(paths, fts_options, NULL) ;
>    if (ftsp == NULL) {
>        return -2 ;
>    }
> 
>    FTSENT* ftsPointer = 0 ;
>    while ((ftsPointer = fts_read(ftsp)) != NULL) {
>        /*
>         This will execute once for each item in the tree.
>         According to the man page fts(3):
>         "directories are visited two distinguishable times; in pre-order
>         (before any of their descendants are visited) and in post-order
>         (after all of their descendants have been visited)"
>         But my doSomething() only logs once for each directory, in pre-order. 
>  Example:
>         Doing /Users/jk/Desktop/OW5/.
>         Doing /Users/jk/Desktop/OW5/..
>         Doing /Users/jk/Desktop/OW5/BkmxTemp/.
>         Doing /Users/jk/Desktop/OW5/BkmxTemp/..
>         Doing /Users/jk/Desktop/OW5/BkmxTemp/placesNo1Dump.txt
>         Doing /Users/jk/Desktop/OW5/BkmxTemp/placesOk1Dump.txt
>         Apparently a "visit" does not mean "returned by ftsPointer->fts_info"
>         */
>        int result ;
>        switch (ftsPointer->fts_info) { 
>                // List here the file types you want to doSomething to.
>                // Again, see man fts(3).
>            case FTS_D:     // directory
>            case FTS_F:     // regular file
>            case FTS_DOT:   // system dot file, i.e. '.' or '..' 
>            case FTS_SL:    // symbolic link
>                result = doSomething(ftsPointer->fts_path) ;
>                if (result != 0) {
>                    // Break out due to error
>                    return result ;
>                }
>                break ;
> 
>            default:
>                break; 
>        }
>    }
> 
>    fts_close(ftsp) ;
> 
>    return 0 ;
> }
> 
> int main (int argc, const char * argv[]) {
>    doSomething_recursive("/Users/jk/Desktop/OW5") ;
>    return 0 ;
> }
> 
> _______________________________________________
> 
> Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)
> 
> Please do not post admin requests or moderator comments to the list.
> Contact the moderators at cocoa-dev-admins(at)lists.apple.com
> 
> Help/Unsubscribe/Update your Subscription:
> http://lists.apple.com/mailman/options/cocoa-dev/tjones%40acworld.com
> 
> This email sent to tjo...@acworld.com

_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
http://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to arch...@mail-archive.com

Reply via email to