From bd6336c629841c6db3a6ca53a936d629d34db53b Mon Sep 17 00:00:00 2001 From: Daniel Wilhelm Date: Fri, 18 Apr 2014 17:15:16 +0200 Subject: 4.1 --- shared/file_id.cpp | 67 ------------------------------------------------------ 1 file changed, 67 deletions(-) delete mode 100644 shared/file_id.cpp (limited to 'shared/file_id.cpp') diff --git a/shared/file_id.cpp b/shared/file_id.cpp deleted file mode 100644 index 198598b4..00000000 --- a/shared/file_id.cpp +++ /dev/null @@ -1,67 +0,0 @@ -// ************************************************************************** -// * 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) 2008-2011 ZenJu (zhnmju123 AT gmx.de) * -// ************************************************************************** - -#include "file_id.h" -#include "file_id_internal.h" - -#ifdef FFS_WIN -#include //includes "windows.h" -#include "long_path_prefix.h" -#include "loki/ScopeGuard.h" - -#elif defined FFS_LINUX -#include -#endif - - -std::string util::retrieveFileID(const Zstring& filename) -{ -#ifdef FFS_WIN - //WARNING: CreateFile() is SLOW, while GetFileInformationByHandle() is cheap! - //http://msdn.microsoft.com/en-us/library/aa363788(VS.85).aspx - - //privilege SE_BACKUP_NAME doesn't seem to be required here at all - - const HANDLE hFile = ::CreateFile(zen::applyLongPathPrefix(filename).c_str(), - 0, - FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE, - 0, - OPEN_EXISTING, - FILE_FLAG_OPEN_REPARSE_POINT | FILE_FLAG_BACKUP_SEMANTICS, //FILE_FLAG_BACKUP_SEMANTICS needed to open a directory - NULL); - if (hFile != INVALID_HANDLE_VALUE) - { - LOKI_ON_BLOCK_EXIT2(::CloseHandle(hFile)); - - BY_HANDLE_FILE_INFORMATION fileInfo = {}; - if (::GetFileInformationByHandle(hFile, &fileInfo)) - return extractFileID(fileInfo); - } - -#elif defined FFS_LINUX - struct stat fileInfo = {}; - if (::lstat(filename.c_str(), &fileInfo) == 0) //lstat() does not follow symlinks - return extractFileID(fileInfo); -#endif - - assert(false); - return std::string(); -} - - -bool util::sameFileSpecified(const Zstring& file1, const Zstring& file2) -{ - if (EqualFilename()(file1, file2)) //quick check - return true; - - const std::string id1 = retrieveFileID(file1); - const std::string id2 = retrieveFileID(file2); - - if (id1.empty() || id2.empty()) - return false; - - return id1 == id2; -} -- cgit