X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Ffs%2Fdir.cpp;h=ea0cd952b5a77ad159d625664f6d0ed8991900d4;hp=2575beb76580de0578c51f9da5aa38041e77aabd;hb=64b635de88d64a3650136182d7a584aece103e15;hpb=e297edc38785ae5931685f6b1d6efdef97fc5c10 diff --git a/source/fs/dir.cpp b/source/fs/dir.cpp index 2575beb..ea0cd95 100644 --- a/source/fs/dir.cpp +++ b/source/fs/dir.cpp @@ -1,11 +1,11 @@ #include #include #include -#include #ifdef WIN32 #include #else #include +#include #endif #include #include @@ -64,17 +64,14 @@ not_a_directory::not_a_directory(const Path &p): void mkdir(const Path &path, int mode) { - int err; #ifdef WIN32 - // The win32 version of this function doesn't take the mode argument. Go figure. (void)mode; - err = ::mkdir(path.str().c_str()); + if(!CreateDirectory(path.str().c_str(), NULL)) + throw system_error("CreateDirectory"); #else - err = ::mkdir(path.str().c_str(), mode); -#endif - - if(err==-1) + if(::mkdir(path.str().c_str(), mode)==-1) throw system_error("mkdir"); +#endif } void mkpath(const Path &path, int mode) @@ -100,8 +97,13 @@ void mkpath(const Path &path, int mode) void rmdir(const Path &path) { +#ifdef WIN32 + if(!RemoveDirectory(path.str().c_str())) + throw system_error("RemoveDirectory"); +#else if(::rmdir(path.str().c_str())==-1) throw system_error("rmdir"); +#endif } void rmpath(const Path &path)