diff options
author | Joey Hess <joey@kitenet.net> | 2013-02-26 13:49:22 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2013-02-26 14:35:39 -0400 |
commit | cbfcd75214a648bf204f8356a28e360229542bde (patch) | |
tree | 4b63d28522c4c73dc4847d66fffe1bcf3864c0b9 | |
parent | c7e198390bfe3911943bc74836d7519c5ae37674 (diff) |
fix * glob matching files in subdirectories
-rw-r--r-- | Limit.hs | 18 | ||||
-rw-r--r-- | debian/changelog | 3 | ||||
-rw-r--r-- | git-annex.cabal | 5 | ||||
-rw-r--r-- | test.hs | 8 |
4 files changed, 18 insertions, 16 deletions
@@ -12,12 +12,8 @@ module Limit where import Data.Time.Clock.POSIX import qualified Data.Set as S import qualified Data.Map as M -#ifdef WITH_GLOB -import "Glob" System.FilePath.Glob (simplify, compile, match) -#else -import Text.Regex.PCRE.Light.Char8 import System.Path.WildMatch -#endif +import Text.Regex import Common.Annex import qualified Annex @@ -86,18 +82,14 @@ addExclude = addLimit . limitExclude limitExclude :: MkLimit limitExclude glob = Right $ const $ return . not . matchglob glob +{- Could just use wildCheckCase, but this way the regex is only compiled + - once. -} matchglob :: String -> Annex.FileInfo -> Bool matchglob glob (Annex.FileInfo { Annex.matchFile = f }) = -#ifdef WITH_GLOB - match pattern f + isJust $ matchRegex cregex f where - pattern = simplify $ compile glob -#else - isJust $ match cregex f [] - where - cregex = compile regex [] + cregex = mkRegex regex regex = '^':wildToRegex glob -#endif {- Adds a limit to skip files not believed to be present - in a specfied repository. -} diff --git a/debian/changelog b/debian/changelog index cb384bc6e..9f68bc523 100644 --- a/debian/changelog +++ b/debian/changelog @@ -16,6 +16,9 @@ git-annex (3.20130217) UNRELEASED; urgency=low * Additional GIT_DIR support bugfixes. May actually work now. * webapp: Display any error message from git init if it fails to create a repository. + * Fix a reversion in matching globs introduced in the last release, + where "*" did not match files inside subdirectories. No longer uses + the Glob library. -- Joey Hess <joeyh@debian.org> Sun, 17 Feb 2013 16:42:16 -0400 diff --git a/git-annex.cabal b/git-annex.cabal index 6bfb8a06e..3383a6895 100644 --- a/git-annex.cabal +++ b/git-annex.cabal @@ -60,14 +60,13 @@ Executable git-annex extensible-exceptions, dataenc, SHA, process, json, base (>= 4.5 && < 4.8), monad-control, transformers-base, lifted-base, IfElse, text, QuickCheck >= 2.1, bloomfilter, edit-distance, process, - SafeSemaphore, uuid, random, Glob + SafeSemaphore, uuid, random -- Need to list these because they're generated from .hsc files. Other-Modules: Utility.Touch Utility.Mounts Include-Dirs: Utility C-Sources: Utility/libdiskfree.c Utility/libmounts.c Extensions: CPP GHC-Options: -threaded - CPP-Options: -DWITH_GLOB if flag(S3) Build-Depends: hS3 @@ -127,7 +126,7 @@ Test-Suite test old-locale, time, extensible-exceptions, dataenc, SHA, process, json, base (>= 4.5 && < 4.7), monad-control, transformers-base, lifted-base, IfElse, text, QuickCheck >= 2.1, - bloomfilter, edit-distance, process, SafeSemaphore, Glob, random, uuid + bloomfilter, edit-distance, process, SafeSemaphore, random, uuid Other-Modules: Utility.Touch Include-Dirs: Utility C-Sources: Utility/libdiskfree.c @@ -560,6 +560,14 @@ test_find = "git-annex find" ~: intmpclonerepo $ do git_annex_expectoutput "find" ["--inbackend", "SHA1"] [sha1annexedfile] git_annex_expectoutput "find" ["--inbackend", "WORM"] [] + {- --include=* should match files in subdirectories too, + - and --exclude=* should exclude them. -} + createDirectory "dir" + writeFile "dir/subfile" "subfile" + git_annex "add" ["dir"] @? "add of subdir failed" + git_annex_expectoutput "find" ["--include", "*", "--exclude", annexedfile, "--exclude", sha1annexedfile] ["dir/subfile"] + git_annex_expectoutput "find" ["--exclude", "*"] [] + test_merge :: Test test_merge = "git-annex merge" ~: intmpclonerepo $ do git_annex "merge" [] @? "merge failed" |