Safe Haskell | None |
---|---|
Language | Haskell2010 |
Synopsis
- newtype Q k = Q (k, NormalizedFilePath)
- newtype A v = A (Value v)
- data Value v
- data ValueWithDiagnostics = ValueWithDiagnostics !(Value Dynamic) !(Vector FileDiagnostic)
- type Values = HashMap (NormalizedFilePath, Key) ValueWithDiagnostics
- data Key = forall k.(Typeable k, Hashable k, Eq k, NFData k, Show k) => Key k
- data SomeShakeValue
- newtype BadDependency = BadDependency String
- data ShakeValue
- currentValue :: Value v -> Maybe v
- isBadDependency :: SomeException -> Bool
- toShakeValue :: (ByteString -> ShakeValue) -> Maybe ByteString -> ShakeValue
- encodeShakeValue :: ShakeValue -> ByteString
- decodeShakeValue :: ByteString -> ShakeValue
- toKey :: ShakeValue k => k -> NormalizedFilePath -> SomeShakeValue
- toNoFileKey :: (Show k, Typeable k, Eq k, Hashable k, Binary k, NFData k) => k -> SomeShakeValue
Documentation
Q (k, NormalizedFilePath) |
Instances
Eq k => Eq (Q k) Source # | |
Show k => Show (Q k) Source # | |
Hashable k => Hashable (Q k) Source # | |
Defined in Development.IDE.Types.Shake | |
Binary k => Binary (Q k) Source # | |
NFData k => NFData (Q k) Source # | |
Defined in Development.IDE.Types.Shake | |
type RuleResult (Q k) Source # | |
Defined in Development.IDE.Types.Shake |
Invariant: the v
must be in normal form (fully evaluated).
Otherwise we keep repeatedly rnf
ing values taken from the Shake database
Instances
type Values = HashMap (NormalizedFilePath, Key) ValueWithDiagnostics Source #
The state of the all values and diagnostics
Key type
data SomeShakeValue #
Instances
Eq SomeShakeValue | |
Defined in Development.IDE.Graph.Database (==) :: SomeShakeValue -> SomeShakeValue -> Bool # (/=) :: SomeShakeValue -> SomeShakeValue -> Bool # | |
Show SomeShakeValue | |
Defined in Development.IDE.Graph.Database showsPrec :: Int -> SomeShakeValue -> ShowS # show :: SomeShakeValue -> String # showList :: [SomeShakeValue] -> ShowS # | |
Hashable SomeShakeValue | |
Defined in Development.IDE.Graph.Database hashWithSalt :: Int -> SomeShakeValue -> Int # hash :: SomeShakeValue -> Int # |
newtype BadDependency Source #
When we depend on something that reported an error, and we fail as a direct result, throw BadDependency which short-circuits the rest of the action
Instances
Show BadDependency Source # | |
Defined in Development.IDE.Types.Shake showsPrec :: Int -> BadDependency -> ShowS # show :: BadDependency -> String # showList :: [BadDependency] -> ShowS # | |
Exception BadDependency Source # | |
Defined in Development.IDE.Types.Shake |
data ShakeValue Source #
ShakeNoCutoff | This is what we use when we get Nothing from a rule. |
ShakeResult !ByteString | |
ShakeStale !ByteString |
Instances
currentValue :: Value v -> Maybe v Source #
Convert a Value to a Maybe. This will only return Just
for
up2date results not for stale values.
isBadDependency :: SomeException -> Bool Source #
toShakeValue :: (ByteString -> ShakeValue) -> Maybe ByteString -> ShakeValue Source #
toKey :: ShakeValue k => k -> NormalizedFilePath -> SomeShakeValue Source #
toNoFileKey :: (Show k, Typeable k, Eq k, Hashable k, Binary k, NFData k) => k -> SomeShakeValue Source #