From f2c70dfaba8d6481e86646080c51b6874d95f14e Mon Sep 17 00:00:00 2001 From: dec05eba Date: Tue, 12 Dec 2017 19:46:57 +0100 Subject: Lazily create directories that are needed Directories such as: ~/.sibs ~/.sibs/archive ~/.sibs/lib And directories for each specific library. Also fix bug in getFileContent and fileOverwrite if file already exists --- src/FileUtil.cpp | 80 ++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 72 insertions(+), 8 deletions(-) (limited to 'src/FileUtil.cpp') diff --git a/src/FileUtil.cpp b/src/FileUtil.cpp index d815ebf..9a15938 100644 --- a/src/FileUtil.cpp +++ b/src/FileUtil.cpp @@ -6,6 +6,7 @@ #include #include #include +#include #endif using namespace std; @@ -84,10 +85,14 @@ namespace sibs Result getFileContent(const char *filepath) { FILE *file = fopen(filepath, "rb"); - if(!file || errno != 0) + if(!file) { - perror(filepath); - return Result::Err("Failed to open file"); + int error = errno; + string errMsg = "Failed to open file: "; + errMsg += filepath; + errMsg += "; reason: "; + errMsg += strerror(error); + return Result::Err(errMsg); } fseek(file, 0, SEEK_END); @@ -108,17 +113,21 @@ namespace sibs return Result::Ok(StringView(result, fileSize)); } - bool fileOverwrite(const char *filepath, StringView data) + Result fileOverwrite(const char *filepath, StringView data) { FILE *file = fopen(filepath, "wb"); - if(!file || errno != 0) + if(!file) { - perror(filepath); - return false; + int error = errno; + string errMsg = "Failed to overwrite file: "; + errMsg += filepath; + errMsg += "; reason: "; + errMsg += strerror(error); + return Result::Err(errMsg); } fwrite(data.data, 1, data.size, file); fclose(file); - return true; + return Result::Ok(true); } const char* getHomeDir() @@ -144,4 +153,59 @@ namespace sibs return Result::Err(strerror(errno)); } + +#if OS_FAMILY == OS_FAMILY_POSIX + Result createDirectoryRecursive(const char *path) + { + char pathBuffer[PATH_MAX]; + size_t pathLength = strlen(path); + if(pathLength > sizeof(pathBuffer) - 1) + { + string errMsg = "Directory path too long: "; + errMsg += string(path, pathLength); + return Result::Err(errMsg, ENAMETOOLONG); + } + strcpy(pathBuffer, path); + + char *p = pathBuffer; + for(size_t i = 0; i < pathLength; ++i) + { + if(i > 0 && *p == '/') + { + *p = '\0'; + if(mkdir(pathBuffer, S_IRWXU) != 0) + { + int error = errno; + if(error != EEXIST) + { + string errMsg = "Failed to create directory: "; + errMsg += pathBuffer; + errMsg += "; reason: "; + errMsg += strerror(error); + return Result::Err(errMsg, error); + } + } + *p = '/'; + } + ++p; + } + + if(mkdir(pathBuffer, S_IRWXU) != 0) + { + int error = errno; + if(error != EEXIST) + { + string errMsg = "Failed to create directory: "; + errMsg += pathBuffer; + errMsg += "; reason: "; + errMsg += strerror(error); + return Result::Err(errMsg, error); + } + } + + return Result::Ok(true); + } +#else +#error "TODO: Implement createDirectoryRecursive on windows" +#endif } \ No newline at end of file -- cgit v1.2.3