diff options
author | Joey Hess <joey@kitenet.net> | 2014-02-17 00:18:57 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2014-02-17 00:18:57 -0400 |
commit | f3865432b036c4e98a4012e9af4d0b1df787383c (patch) | |
tree | c500b5a7c18add2d3e6a6e2d151c3317cc68e48a /Annex/View.hs | |
parent | d2455918de02e407c463597d4656aeb9adb59010 (diff) |
split out types
Diffstat (limited to 'Annex/View.hs')
-rw-r--r-- | Annex/View.hs | 43 |
1 files changed, 1 insertions, 42 deletions
diff --git a/Annex/View.hs b/Annex/View.hs index aef9e0a66..458a2688d 100644 --- a/Annex/View.hs +++ b/Annex/View.hs @@ -10,15 +10,13 @@ module Annex.View where import Common.Annex -import Logs.MetaData +import Types.View import Types.MetaData import qualified Git.Types as Git import qualified Git.Ref import qualified Git.DiffTree import qualified Git.Branch -import qualified Git.Index import Git.Sha (nullSha) -import Utility.QuickCheck import qualified Data.Set as S import Data.Char @@ -31,42 +29,6 @@ import Text.Regex.TDFA.String #else #endif -type View = [(MetaField, ViewFilter)] - -data ViewFilter - = FilterValues (S.Set MetaValue) - | FilterGlob Glob - -instance Show ViewFilter where - show (FilterValues s) = show s - show (FilterGlob g) = getGlob g - -instance Eq ViewFilter where - FilterValues x == FilterValues y = x == y - FilterGlob x == FilterGlob y = x == y - _ == _ = False - -instance Arbitrary ViewFilter where - arbitrary = do - size <- arbitrarySizedBoundedIntegral `suchThat` (< 100) - FilterValues . S.fromList <$> vector size - -#ifdef WITH_TDFA -data Glob = Glob String Regex -#else -data Glob = Glob String -#endif - -instance Eq Glob where - a == b = getGlob a == getGlob b - -getGlob :: Glob -> String -#ifdef WITH_TDFA -getGlob (Glob g _) = g -#else -getGlob (Glob g) = g -#endif - matchGlob :: Glob -> String -> Bool #ifdef WITH_TDFA matchGlob (Glob _ r) s = case execute r s of @@ -153,9 +115,6 @@ multiValue (FilterGlob _) = True viewTooLarge :: View -> Bool viewTooLarge view = length (filter (multiValue . snd) view) > 5 -type FileView = FilePath -type MkFileView = FilePath -> FileView - {- Checks if metadata matches a filter, and if so returns the value, - or values that match. -} matchFilter :: MetaData -> MetaField -> ViewFilter -> Maybe [MetaValue] |