Problem
You have to remove or rename a file, and you want to do it portably, i.e., without using OS-specific APIs.
Solution
The Standard C functions remove and rename, in , will do this. See Example 10-11 for a brief demonstration of them.
Example 10-11. Removing a file
#include #include #include using namespace std; int main(int argc, char** argv) { if (argc != 2) { cerr << "You must supply a file name to remove." << endl; return(EXIT_FAILURE); } if (remove(argv[1]) == -1) { // remove( ) returns -1 on error cerr << "Error: " << strerror(errno) << endl; return(EXIT_FAILURE); } else { cout << "File '" << argv[1] << "' removed." << endl; } }
Discussion
These system calls are easy to use: just call one or the other with the filename you want to delete or rename. If something goes wrong, the return value is non-zero and errno is set to the appropriate error number. You can use strerror or perror (both declared in ) to print out the implementation-defined error message.
To rename a file, you can replace the remove call in Example 10-11 with the following code:
if (rename(argv[1], argv[2])) { cerr << "Error: " << strerror(errno) << endl; return(EXIT_FAILURE); }
The Boost Filesystem library also provides the ability to remove or rename a file. Example 10-12 shows a short program for removing a file (or directory, but see the discussion after the example).
Example 10-12. Removing a file with Boost
#include #include #include #include using namespace std; using namespace boost::filesystem; int main(int argc, char** argv) { // Do parameter checking... try { path p = complete(path(argv[1], native)); remove(p); } catch (exception& e) { cerr << e.what( ) << endl; } return(EXIT_SUCCESS); }
The important part of Example 10-12 is the remove function. Call it with a valid path argument that refers to a file or an empty directory, and it will be removed. For an explanation of the path class and complete function, both of which are part of the Boost Filesystem library, take a look at the discussion in Recipe 10.7. See Recipe 10.11 for an example of how to remove a directory and all the files it contains.
Renaming a file or directory is similar. Replace the code in the TRy block in Example 10-12 with this code:
path src=complete(path(argv[1], native)); path dst = complete(path(argv[2], native)); rename(src, dst);
This will rename src to dst, so long as each is a valid path. src and dst don't have to have a common base directory, and in that respect, the rename function logically moves a file or directory to a new base directory, so long as dst exists.
See Also
Recipe 10.7
Building C++ Applications
Code Organization
Numbers
Strings and Text
Dates and Times
Managing Data with Containers
Algorithms
Classes
Exceptions and Safety
Streams and Files
Science and Mathematics
Multithreading
Internationalization
XML
Miscellaneous
Index