summaryrefslogtreecommitdiff
path: root/distrib/compare/compare.hs
diff options
context:
space:
mode:
Diffstat (limited to 'distrib/compare/compare.hs')
-rw-r--r--distrib/compare/compare.hs93
1 files changed, 46 insertions, 47 deletions
diff --git a/distrib/compare/compare.hs b/distrib/compare/compare.hs
index d1a8ac7fdd..0e0e9f8306 100644
--- a/distrib/compare/compare.hs
+++ b/distrib/compare/compare.hs
@@ -33,39 +33,41 @@ main = do args <- getArgs
doit :: Bool -> FilePath -> FilePath -> IO ()
doit ignoreSizeChanges bd1 bd2
- = do let windows = any ("mingw" `isPrefixOf`) (tails bd1)
- tls1 <- readTarLines bd1
+ = do tls1 <- readTarLines bd1
tls2 <- readTarLines bd2
- -- If it looks like we have a Windows "bindist" then just
- -- set ways to [] for now.
- ways1 <- if windows then return []
- else dieOnErrors $ findWays tls1
- ways2 <- if windows then return []
- else dieOnErrors $ findWays tls2
- (content1, tvm1) <- dieOnErrors $ mkContents ways1 tls1
- (content2, tvm2) <- dieOnErrors $ mkContents ways2 tls2
+ let mWays1 = findWays tls1
+ mWays2 = findWays tls2
+ wayDifferences <- case (mWays1, mWays2) of
+ (Nothing, Nothing) ->
+ return []
+ (Just ways1, Just ways2) ->
+ return $ diffWays ways1 ways2
+ _ ->
+ die ["One input has ways, but the other doesn't"]
+ (content1, tvm1) <- dieOnErrors $ mkContents mWays1 tls1
+ (content2, tvm2) <- dieOnErrors $ mkContents mWays2 tls2
let sortedContent1 = sortByFst content1
sortedContent2 = sortByFst content2
(nubProbs1, nubbedContent1) = nubContents sortedContent1
(nubProbs2, nubbedContent2) = nubContents sortedContent2
- differences = compareContent ways1 nubbedContent1
- ways2 nubbedContent2
+ differences = compareContent mWays1 nubbedContent1
+ mWays2 nubbedContent2
allProbs = map First nubProbs1 ++ map Second nubProbs2
++ diffThingVersionMap tvm1 tvm2
- ++ diffWays ways1 ways2
+ ++ wayDifferences
++ differences
wantedProbs = if ignoreSizeChanges
then filter (not . isSizeChange) allProbs
else allProbs
mapM_ (putStrLn . pprFileChange) wantedProbs
-findWays :: [TarLine] -> Either Errors Ways
-findWays = foldr f (Left ["Couldn't find ways"])
- where f tl res = case re regex (tlFileName tl) of
- Just [dashedWays] ->
- Right (unSepList '-' dashedWays)
- _ ->
- res
+-- *nix bindists have ways.
+-- Windows "bindists", install trees, and testsuites don't.
+findWays :: [TarLine] -> Maybe Ways
+findWays tls = msum $ map f tls
+ where f tl = case re regex (tlFileName tl) of
+ Just [dashedWays] -> Just (unSepList '-' dashedWays)
+ _ -> Nothing
regex = "/libraries/base/dist-install/build/\\.depend-(.*)\\.haskell"
diffWays :: Ways -> Ways -> [FileChange]
@@ -93,10 +95,10 @@ diffThingVersionMap tvm1 tvm2 = f (sortByFst tvm1) (sortByFst tvm2)
else [Change (ThingVersionChanged xt xv yv)]
in this ++ f xs' ys'
-mkContents :: Ways -> [TarLine]
+mkContents :: Maybe Ways -> [TarLine]
-> Either Errors ([(FilenameDescr, TarLine)], ThingVersionMap)
-mkContents ways tls
- = case runStateT (mapM f tls) (emptyBuildInfo ways) of
+mkContents mWays tls
+ = case runStateT (mapM f tls) (emptyBuildInfo mWays) of
Nothing -> Left ["Can't happen: mkContents: Nothing"]
Just (xs, finalBuildInfo) ->
case concat $ map (checkContent finalBuildInfo) xs of
@@ -211,36 +213,33 @@ mkFileNameDescr filename
| Just [dashedWays, depType]
<- re "^\\.depend-(.*)\\.(haskell|c_asm)"
filename
- = do ways <- getWays
- if unSepList '-' dashedWays == ways
+ = do mWays <- getMaybeWays
+ if Just (unSepList '-' dashedWays) == mWays
then return [FP ".depend-", Ways, FP ".", FP depType]
else unchanged
| otherwise = unchanged
where unchanged = return [FP filename]
-compareContent :: Ways -> [(FilenameDescr, TarLine)]
- -> Ways -> [(FilenameDescr, TarLine)]
+compareContent :: Maybe Ways -> [(FilenameDescr, TarLine)]
+ -> Maybe Ways -> [(FilenameDescr, TarLine)]
-> [FileChange]
-compareContent _ [] _ [] = []
-compareContent _ xs _ [] = map (First . ExtraFile . tlFileName . snd) xs
-compareContent _ [] _ ys = map (Second . ExtraFile . tlFileName . snd) ys
-compareContent ways1 xs1 ways2 xs2
- = case (xs1, xs2) of
- ([], []) -> []
- (xs, []) -> concatMap (mkExtraFile ways1 First . tlFileName . snd) xs
- ([], ys) -> concatMap (mkExtraFile ways2 Second . tlFileName . snd) ys
- ((fd1, tl1) : xs1', (fd2, tl2) : xs2') ->
- case fd1 `compare` fd2 of
- EQ -> map Change (compareTarLine tl1 tl2)
- ++ compareContent ways1 xs1' ways2 xs2'
- LT -> mkExtraFile ways1 First (tlFileName tl1)
- ++ compareContent ways1 xs1' ways2 xs2
- GT -> mkExtraFile ways2 Second (tlFileName tl2)
- ++ compareContent ways1 xs1 ways2 xs2'
- where mkExtraFile ways mkFileChange filename
- = case findFileWay filename of
- Just way
- | way `elem` ways -> []
+compareContent mWays1 xs1all mWays2 xs2all
+ = f xs1all xs2all
+ where f [] [] = []
+ f xs [] = concatMap (mkExtraFile mWays1 mWays2 First . tlFileName . snd) xs
+ f [] ys = concatMap (mkExtraFile mWays2 mWays1 Second . tlFileName . snd) ys
+ f xs1@((fd1, tl1) : xs1') xs2@((fd2, tl2) : xs2')
+ = case fd1 `compare` fd2 of
+ EQ -> map Change (compareTarLine tl1 tl2)
+ ++ f xs1' xs2'
+ LT -> mkExtraFile mWays1 mWays2 First (tlFileName tl1)
+ ++ f xs1' xs2
+ GT -> mkExtraFile mWays2 mWays1 Second (tlFileName tl2)
+ ++ f xs1 xs2'
+ mkExtraFile mWaysMe mWaysThem mkFileChange filename
+ = case (findFileWay filename, mWaysMe, mWaysThem) of
+ (Just way, Just waysMe, Just waysThem)
+ | (way `elem` waysMe) && not (way `elem` waysThem) -> []
_ -> [mkFileChange (ExtraFile filename)]
findFileWay :: FilePath -> Maybe String