Skip to content

Commit

Permalink
Use NubList
Browse files Browse the repository at this point in the history
  • Loading branch information
philderbeast committed May 15, 2024
1 parent 5dffc1e commit 2f68e8b
Showing 1 changed file with 8 additions and 8 deletions.
16 changes: 8 additions & 8 deletions cabal-install/src/Distribution/Client/ProjectConfig/Legacy.hs
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,6 @@ import Distribution.Simple.Setup
import Distribution.Simple.Utils
( debug
, lowercase
, ordNub
)
import Distribution.Types.CondTree
( CondBranch (..)
Expand All @@ -139,7 +138,8 @@ import Distribution.Types.CondTree
)
import Distribution.Types.SourceRepo (RepoType)
import Distribution.Utils.NubList
( fromNubList
( NubList
, fromNubList
, overNubList
, toNubList
)
Expand Down Expand Up @@ -249,14 +249,14 @@ parseProject rootPath cacheDir httpTransport verbosity configToParse = do
let (dir, projectFileName) = splitFileName rootPath
projectDir <- makeAbsolute dir
projectPath@(ProjectConfigPath (canonicalRoot :| _)) <- canonicalizeConfigPath projectDir (ProjectConfigPath $ projectFileName :| [])
importsBy <- newIORef [(canonicalRoot, projectPath)]
importsBy <- newIORef $ toNubList [(canonicalRoot, projectPath)]
parseProjectSkeleton cacheDir httpTransport verbosity importsBy projectDir projectPath configToParse

parseProjectSkeleton
:: FilePath
-> HttpTransport
-> Verbosity
-> IORef [(FilePath, ProjectConfigPath)]
-> IORef (NubList (FilePath, ProjectConfigPath))
-- ^ The imports seen so far, used to report on cycles and duplicates and to detect duplicates that are not cycles
-> FilePath
-- ^ The directory of the project configuration, typically the directory of cabal.project
Expand All @@ -275,18 +275,18 @@ parseProjectSkeleton cacheDir httpTransport verbosity importsBy projectDir sourc

-- Once we canonicalize the import path, we can check for cyclical and duplicate imports
normLocPath@(ProjectConfigPath (uniqueImport :| _)) <- canonicalizeConfigPath projectDir importLocPath
seenImportsBy@(fmap fst -> seenImports) <- atomicModifyIORef' importsBy (\ibs -> (ordNub $ (uniqueImport, normLocPath) : ibs, ibs))
seenImportsBy@(fmap fst . fromNubList -> seenImports) <- atomicModifyIORef' importsBy (\ibs -> (toNubList [(uniqueImport, normLocPath)] <> ibs, ibs))

debug verbosity $ "\nimport path, normalized\n=======================\n" ++ render (docProjectConfigPath normLocPath)
debug verbosity "\nseen unique paths\n================="
mapM_ (debug verbosity . fst) seenImportsBy
mapM_ (debug verbosity) seenImports
debug verbosity "\n"

if
| isCyclicConfigPath normLocPath ->
pure . parseFail $ ParseUtils.FromString (render $ duplicateImportMsg "cyclical (duplicate)" uniqueImport normLocPath seenImportsBy) Nothing
pure . parseFail $ ParseUtils.FromString (render $ duplicateImportMsg "cyclical (duplicate)" uniqueImport normLocPath (fromNubList seenImportsBy)) Nothing
| uniqueImport `elem` seenImports -> do
pure . parseFail $ ParseUtils.FromString (render $ duplicateImportMsg "duplicate" uniqueImport normLocPath seenImportsBy) Nothing
pure . parseFail $ ParseUtils.FromString (render $ duplicateImportMsg "duplicate" uniqueImport normLocPath (fromNubList seenImportsBy)) Nothing
| otherwise -> do
normSource <- canonicalizeConfigPath projectDir source
let fs = (\z -> CondNode z [normLocPath] mempty) <$> fieldsToConfig normSource (reverse acc)
Expand Down

0 comments on commit 2f68e8b

Please sign in to comment.