-
Notifications
You must be signed in to change notification settings - Fork 701
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
21 changed files
with
245 additions
and
55 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
{-# LANGUAGE DeriveDataTypeable #-} | ||
{-# LANGUAGE DeriveGeneric #-} | ||
|
||
module Distribution.Types.DefaultBound where | ||
|
||
import Distribution.Compat.Prelude | ||
|
||
import Distribution.Types.Dependency | ||
import Distribution.Types.ExeDependency | ||
import Distribution.Types.PackageName | ||
import Distribution.Types.PkgconfigDependency | ||
import Distribution.Types.PkgconfigName | ||
import Distribution.Types.PkgconfigVersionRange | ||
import Distribution.Types.UnqualComponentName | ||
import Distribution.Types.VersionRange | ||
|
||
import Distribution.Parsec | ||
import Distribution.Pretty | ||
|
||
import qualified Distribution.Compat.CharParsing as P | ||
|
||
-- | Describes a default bound on a package, executable or pkg-config package. | ||
data DefaultBound | ||
= DefaultUnqualBound PackageName VersionRange | ||
| DefaultQualBound PackageName UnqualComponentName VersionRange | ||
deriving (Generic, Read, Show, Eq, Ord, Typeable, Data) | ||
|
||
applyDefaultBoundToDependency :: Dependency -> DefaultBound -> Dependency | ||
applyDefaultBoundToDependency dep@(Dependency pkg vorig l) (DefaultUnqualBound pkg' v) | ||
| pkg == pkg' && isAnyVersion vorig = Dependency pkg v l | ||
| otherwise = dep | ||
applyDefaultBoundToDependency dep _ = dep | ||
|
||
applyDefaultBoundToExeDependency :: ExeDependency -> DefaultBound -> ExeDependency | ||
applyDefaultBoundToExeDependency dep@(ExeDependency pkg comp vorig) (DefaultQualBound pkg' comp' v) | ||
| pkg == pkg' && comp == comp' && isAnyVersion vorig = ExeDependency pkg comp v | ||
| otherwise = dep | ||
applyDefaultBoundToExeDependency dep _ = dep | ||
|
||
applyDefaultBoundToPkgconfigDependency :: PkgconfigDependency -> DefaultBound -> PkgconfigDependency | ||
applyDefaultBoundToPkgconfigDependency dep@(PkgconfigDependency pkg PcAnyVersion) (DefaultUnqualBound pkg' v) | ||
| pkg == mkPkgconfigName (unPackageName pkg') = PkgconfigDependency pkg (versionRangeToPkgconfigVersionRange v) | ||
| otherwise = dep | ||
applyDefaultBoundToPkgconfigDependency dep _ = dep | ||
|
||
instance Binary DefaultBound | ||
instance Structured DefaultBound | ||
instance NFData DefaultBound where rnf = genericRnf | ||
|
||
instance Pretty DefaultBound where | ||
pretty (DefaultUnqualBound name ver) = pretty $ Dependency name ver mainLibSet | ||
pretty (DefaultQualBound name comp ver) = pretty $ ExeDependency name comp ver | ||
|
||
instance Parsec DefaultBound where | ||
parsec = do | ||
name <- parsec | ||
mexe <- | ||
( do | ||
_ <- P.char ':' | ||
exe <- lexemeParsec | ||
pure (Just exe) | ||
) | ||
<|> pure Nothing | ||
P.spaces | ||
verRange <- parsec | ||
case mexe of | ||
Nothing -> | ||
pure $ DefaultUnqualBound name verRange | ||
Just exe -> | ||
pure $ DefaultQualBound name exe verRange |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
5 changes: 5 additions & 0 deletions
5
cabal-testsuite/PackageTests/DefaultPackageBounds/bar/Main.hs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
-- | | ||
|
||
module Main where | ||
|
||
main = pure () |
7 changes: 7 additions & 0 deletions
7
cabal-testsuite/PackageTests/DefaultPackageBounds/bar/bar.cabal
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
cabal-version: 3.12 | ||
name: bar | ||
version: 0.1.0.0 | ||
|
||
executable bar | ||
default-language: Haskell2010 | ||
main-is: Main.hs |
Oops, something went wrong.