From 6e07e9e56bc8fd45ad1eb55801ced7f3493684ea Mon Sep 17 00:00:00 2001 From: Julian Ospald Date: Sat, 7 Aug 2021 09:55:45 +0200 Subject: [PATCH] Skip copying metadata if source and destination match --- lib/GHCup/Download.hs | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/lib/GHCup/Download.hs b/lib/GHCup/Download.hs index 981829d..c3f7fe0 100644 --- a/lib/GHCup/Download.hs +++ b/lib/GHCup/Download.hs @@ -321,7 +321,22 @@ download uri eDigest dest mfn etags -- destination dir must exist liftIO $ createDirRecursive' dest let fromFile = T.unpack . decUTF8Safe $ path - liftIO $ copyFile fromFile destFile + + -- clean up etags file + liftIO $ hideError doesNotExistErrorType $ rmFile (etagsFile destFile) + + -- check if source and dest are the same and skip in that case + fromFileNormalized <- handleIO + (\_ -> pure $ normalise fromFile) + (liftIO $ canonicalizePath fromFile) + destFileNormalized <- handleIO + (\_ -> pure $ normalise destFile) + (liftIO $ canonicalizePath destFile) + if | fromFileNormalized /= destFileNormalized -> do + lift $ $(logDebug) [i|cp #{fromFile} #{destFile}|] + liftIO $ copyFile fromFile destFile + | otherwise -> lift $ $(logDebug) [i|destination and source match, skipping: #{destFile}|] + pure destFile dl = do let uri' = decUTF8Safe (serializeURIRef' uri)