Mercurial > jhg
changeset 118:68ba22a2133a
Defects in the filter initialization
author | Artem Tikhomirov <tikhomirov.artem@gmail.com> |
---|---|
date | Fri, 04 Feb 2011 02:44:32 +0100 (2011-02-04) |
parents | 6c0be854d149 |
children | ed2b4adac51c |
files | src/org/tmatesoft/hg/internal/KeywordFilter.java src/org/tmatesoft/hg/internal/NewlineFilter.java src/org/tmatesoft/hg/internal/PathGlobMatcher.java |
diffstat | 3 files changed, 6 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- a/src/org/tmatesoft/hg/internal/KeywordFilter.java Fri Feb 04 02:12:30 2011 +0100 +++ b/src/org/tmatesoft/hg/internal/KeywordFilter.java Fri Feb 04 02:44:32 2011 +0100 @@ -289,7 +289,7 @@ public Filter create(Path path, Options opts) { if (matcher.accept(path)) { - return new KeywordFilter(repo, path, true); + return new KeywordFilter(repo, path, opts.getDirection() == Filter.Direction.FromRepo); } return null; }
--- a/src/org/tmatesoft/hg/internal/NewlineFilter.java Fri Feb 04 02:12:30 2011 +0100 +++ b/src/org/tmatesoft/hg/internal/NewlineFilter.java Fri Feb 04 02:44:32 2011 +0100 @@ -167,7 +167,7 @@ public void initialize(HgRepository hgRepo, ConfigFile cfg) { failIfInconsistent = cfg.getBoolean("eol", "only-consistent", true); - File cfgFile = new File(new HgInternals(hgRepo).getRepositoryDir(), ".hgeol"); + File cfgFile = new File(new HgInternals(hgRepo).getRepositoryDir().getParentFile(), ".hgeol"); if (!cfgFile.canRead()) { return; }
--- a/src/org/tmatesoft/hg/internal/PathGlobMatcher.java Fri Feb 04 02:12:30 2011 +0100 +++ b/src/org/tmatesoft/hg/internal/PathGlobMatcher.java Fri Feb 04 02:44:32 2011 +0100 @@ -58,12 +58,16 @@ boolean needLineEndMatch = glob.charAt(end) != '*'; while (end > 0 && glob.charAt(end) == '*') end--; // remove trailing * that are useless for Pattern.find() StringBuilder sb = new StringBuilder(end*2); + if (glob.charAt(0) != '*') { + sb.append('^'); + } for (int i = 0; i <= end; i++) { char ch = glob.charAt(i); if (ch == '*') { if (glob.charAt(i+1) == '*') { // i < end because we've stripped any trailing * earlier // any char, including path segment separator sb.append(".*?"); + i++; } else { // just path segments sb.append("[^/]*?");