// ************************************************************************** // * This file is part of the FreeFileSync project. It is distributed under * // * GNU General Public License: http://www.gnu.org/licenses/gpl.html * // * Copyright (C) Zenju (zenju AT gmx DOT de) - All Rights Reserved * // ************************************************************************** #ifndef FILEERROR_H_INCLUDED_839567308565656789 #define FILEERROR_H_INCLUDED_839567308565656789 #include #include "zstring.h" #include "utf.h" #include "sys_error.h" //we'll need this later anyway! namespace zen { //A high-level exception class giving detailed context information for end users class FileError { public: explicit FileError(const std::wstring& msg) : msg_(msg) {} FileError(const std::wstring& msg, const std::wstring& details) : msg_(msg + L"\n\n" + details) {} virtual ~FileError() {} const std::wstring& toString() const { return msg_; } private: std::wstring msg_; }; #define DEFINE_NEW_FILE_ERROR(X) struct X : public FileError { X(const std::wstring& msg) : FileError(msg) {} X(const std::wstring& msg, const std::wstring& descr) : FileError(msg, descr) {} }; DEFINE_NEW_FILE_ERROR(ErrorTargetExisting); DEFINE_NEW_FILE_ERROR(ErrorTargetPathMissing); DEFINE_NEW_FILE_ERROR(ErrorFileLocked); DEFINE_NEW_FILE_ERROR(ErrorDifferentVolume); //----------- facilitate usage of std::wstring for error messages -------------------- //allow implicit UTF8 conversion: since std::wstring models a GUI string, convenience is more important than performance inline std::wstring operator+(const std::wstring& lhs, const Zstring& rhs) { return std::wstring(lhs) += utfCvrtTo(rhs); } //we musn't put our overloads in namespace std, but namespace zen (+ using directive) is sufficient inline std::wstring fmtFileName(const Zstring& filename) { std::wstring output; output += L'\"'; output += utfCvrtTo(filename); output += L'\"'; return output; } } #endif //FILEERROR_H_INCLUDED_839567308565656789