From 2dec550cc1c74521a2b1ffd2b5297458dc50eb02 Mon Sep 17 00:00:00 2001 From: Thomas <71355143+thomas694@users.noreply.github.com> Date: Fri, 28 Jun 2024 21:36:31 +0200 Subject: [PATCH] add a 64-bit version for addressing more memory --- appveyor.yml | 6 ++-- finddupe.c | 14 ++++++---- finddupe.sln | 9 ++++++ finddupe.vcxproj | 71 ++++++++++++++++++++++++++++++++++++++++++++++++ myglob.c | 2 +- 5 files changed, 93 insertions(+), 9 deletions(-) diff --git a/appveyor.yml b/appveyor.yml index b906c34..576a99f 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -14,7 +14,9 @@ init: #version: 1.0.{build} image: Visual Studio 2019 configuration: Release -platform: Win32 +platform: + - Win32 + - x64 for: - branches: @@ -27,7 +29,7 @@ build: project: finddupe.sln verbosity: normal artifacts: -- path: Release/*.exe +- path: $(platform)/Release/*.exe name: finddupe deploy: release: finddupe-v$(MY_BUILD_VERSION) diff --git a/finddupe.c b/finddupe.c index 5d8d133..604c49e 100644 --- a/finddupe.c +++ b/finddupe.c @@ -33,6 +33,7 @@ // Version 1.33 (c) Jun 2024 thomas694 // fixed a problem writing filenames with special unicode characters to the batch file // fixed a memory problem with very large amounts of files +// added a 64-bit version for addressing more memory // // finddupe is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by @@ -97,7 +98,7 @@ typedef struct { }Checksum_t; KHASH_MAP_INIT_INT64(hset, Checksum_t) -KHASH_MAP_INIT_INT64(hmap, INT32) +KHASH_MAP_INIT_INT64(hmap, UINT64) // Data structure for file allocations: typedef struct FileData_t FileData_t; @@ -262,7 +263,7 @@ static khiter_t kh_put_fn(INT64 filenameCRC) return k; } -static khiter_t kh_get_fd(INT64 fileSize, int createNew, int* found) +static khiter_t kh_get_fd(UINT64 fileSize, int createNew, int* found) { khint_t k = kh_get(hmap, FileDataMap, fileSize); if (k == kh_end(FileDataMap)) @@ -275,7 +276,7 @@ static khiter_t kh_get_fd(INT64 fileSize, int createNew, int* found) return k; } -static khiter_t kh_put_fd(INT64 fileSize) +static khiter_t kh_put_fd(UINT64 fileSize) { int ret; khint_t k = kh_put(hmap, FileDataMap, fileSize, &ret); @@ -1107,10 +1108,11 @@ int _tmain (int argc, TCHAR **argv) } #endif - if (BatchFileName){ + if (BatchFileName) { BatchFile = _tfopen(BatchFileName, TEXT("w")); - if (BatchFile == NULL){ - _tprintf(TEXT("Unable to open task batch file '%s'\n"), BatchFileName); + if (BatchFile == NULL) { + _ftprintf(stderr, TEXT("Unable to open task batch file '%s'\n"), BatchFileName); + exit(EXIT_FAILURE); } _ftprintf(BatchFile, TEXT("@echo off\n")); _ftprintf(BatchFile, TEXT("REM Batch file for replacing duplicates with hard links\n")); diff --git a/finddupe.sln b/finddupe.sln index ff25ec5..227f41f 100644 --- a/finddupe.sln +++ b/finddupe.sln @@ -7,16 +7,25 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "finddupe", "finddupe.vcxpro EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|x64 = Debug|x64 Debug|Win32 = Debug|Win32 + Release|x64 = Release|x64 Release|Win32 = Release|Win32 EndGlobalSection GlobalSection(ProjectConfigurationPlatforms) = postSolution + {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Debug|x64.ActiveCfg = Debug|x64 + {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Debug|x64.Build.0 = Debug|x64 {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Debug|Win32.ActiveCfg = Debug|Win32 {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Debug|Win32.Build.0 = Debug|Win32 + {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Release|x64.ActiveCfg = Release|x64 + {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Release|x64.Build.0 = Release|x64 {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Release|Win32.ActiveCfg = Release|Win32 {5ACEBB24-9088-4D2B-9B89-0AABE4250D99}.Release|Win32.Build.0 = Release|Win32 EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {3A64AB72-6B0A-47D2-AD66-AF9F429A90A5} + EndGlobalSection EndGlobal diff --git a/finddupe.vcxproj b/finddupe.vcxproj index 31a83ea..1ae50f1 100644 --- a/finddupe.vcxproj +++ b/finddupe.vcxproj @@ -5,10 +5,18 @@ Debug Win32 + + Debug + x64 + Release Win32 + + Release + x64 + {5ACEBB24-9088-4D2B-9B89-0AABE4250D99} @@ -23,6 +31,12 @@ Unicode v142 + + Application + true + Unicode + v142 + Application false @@ -30,21 +44,48 @@ Unicode v142 + + Application + false + true + Unicode + v142 + + + + + + + true + $(SolutionDir)$(Platform)\$(Configuration)\ + $(Platform)\$(Configuration)\ + $(ProjectName) + + + true + $(ProjectName)_x64 false + $(SolutionDir)$(Platform)\$(Configuration)\ + $(Platform)\$(Configuration)\ + $(ProjectName) + + + false + $(ProjectName)_x64 @@ -59,6 +100,19 @@ true + + + + + Level3 + Disabled + WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions) + + + Console + true + + Level3 @@ -76,6 +130,23 @@ true + + + Level3 + + + MaxSpeed + true + true + WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions) + + + Console + true + true + true + + diff --git a/myglob.c b/myglob.c index 29b3dae..2af848f 100644 --- a/myglob.c +++ b/myglob.c @@ -240,7 +240,7 @@ static void Recurse(const TCHAR * Pattern, int FollowReparse, void (*FileFuncPar int NumHave = 0; struct _tfinddata_t finddata; - long find_handle; + intptr_t find_handle; find_handle = _tfindfirst(MatchPattern, &finddata);