// ***************************************************************************** // * This file is part of the FreeFileSync project. It is distributed under * // * GNU General Public License: http://www.gnu.org/licenses/gpl-3.0 * // * Copyright (C) Zenju (zenju AT freefilesync DOT org) - All Rights Reserved * // ***************************************************************************** #ifndef RECYCLER_H_18345067341545 #define RECYCLER_H_18345067341545 #include #include #include "file_error.h" namespace zen { /* -------------------- |Recycle Bin Access| -------------------- Windows ------- -> Recycler API always available: during runtime either SHFileOperation or IFileOperation (since Vista) will be dynamically selected -> COM needs to be initialized before calling any of these functions! CoInitializeEx/CoUninitialize Linux ----- Compiler flags: `pkg-config --cflags gio-2.0` Linker flags: `pkg-config --libs gio-2.0` Already included in package "gtk+-2.0"! */ //move a file or folder to Recycle Bin (deletes permanently if recycler is not available) -> crappy semantics, but we have no choice thanks to Windows' design bool recycleOrDeleteIfExists(const Zstring& itemPath); //throw FileError, return "true" if file/dir was actually deleted #ifdef ZEN_WIN //Win XP: can take a long time if recycle bin is full and drive is slow!!! => buffer result! //Vista and later: dirPath must exist for a valid check! bool recycleBinExists(const Zstring& dirPath, const std::function& onUpdateGui); //throw FileError void recycleOrDeleteIfExists(const std::vector& filePaths, //throw FileError const std::function& onRecycleItem); //optional; currentItem may be empty #endif } #endif //RECYCLER_H_18345067341545