##// END OF EJS Templates
Modify commands.walk to yield a 4-tuple....
Bryan O'Sullivan -
r942:7eb8cbcc default
parent child Browse files
Show More
@@ -42,9 +42,10 b' def matchpats(repo, cwd, pats = [], opts'
42 42 def makewalk(repo, pats, opts, head = ''):
43 43 cwd = repo.getcwd()
44 44 files, matchfn = matchpats(repo, cwd, pats, opts, head)
45 exact = dict(zip(files, files))
45 46 def walk():
46 47 for src, fn in repo.walk(files = files, match = matchfn):
47 yield src, fn, util.pathto(cwd, fn)
48 yield src, fn, util.pathto(cwd, fn), fn in exact
48 49 return files, matchfn, walk()
49 50
50 51 def walk(repo, pats, opts, head = ''):
@@ -375,9 +376,8 b' def help_(ui, cmd=None):'
375 376 def add(ui, repo, *pats, **opts):
376 377 '''add the specified files on the next commit'''
377 378 names = []
378 q = dict(zip(pats, pats))
379 for src, abs, rel in walk(repo, pats, opts):
380 if rel in q or abs in q:
379 for src, abs, rel, exact in walk(repo, pats, opts):
380 if exact:
381 381 names.append(abs)
382 382 elif repo.dirstate.state(abs) == '?':
383 383 ui.status('adding %s\n' % rel)
@@ -386,15 +386,14 b' def add(ui, repo, *pats, **opts):'
386 386
387 387 def addremove(ui, repo, *pats, **opts):
388 388 """add all new files, delete all missing files"""
389 q = dict(zip(pats, pats))
390 389 add, remove = [], []
391 for src, abs, rel in walk(repo, pats, opts):
390 for src, abs, rel, exact in walk(repo, pats, opts):
392 391 if src == 'f' and repo.dirstate.state(abs) == '?':
393 392 add.append(abs)
394 if rel not in q: ui.status('adding ', rel, '\n')
393 if not exact: ui.status('adding ', rel, '\n')
395 394 if repo.dirstate.state(abs) != 'r' and not os.path.exists(rel):
396 395 remove.append(abs)
397 if rel not in q: ui.status('removing ', rel, '\n')
396 if not exact: ui.status('removing ', rel, '\n')
398 397 repo.add(add)
399 398 repo.remove(remove)
400 399
@@ -432,7 +431,7 b' def annotate(ui, repo, *pats, **opts):'
432 431 node = repo.dirstate.parents()[0]
433 432 change = repo.changelog.read(node)
434 433 mmap = repo.manifest.read(change[0])
435 for src, abs, rel in walk(repo, pats, opts):
434 for src, abs, rel, exact in walk(repo, pats, opts):
436 435 if abs not in mmap:
437 436 ui.warn("warning: %s is not in the repository!\n" % rel)
438 437 continue
@@ -629,8 +628,12 b' def debugindexdot(ui, file_):'
629 628 def debugwalk(ui, repo, *pats, **opts):
630 629 items = list(walk(repo, pats, opts))
631 630 if not items: return
632 fmt = '%%s %%-%ds %%s' % max([len(abs) for (src, abs, rel) in items])
633 for i in items: print fmt % i
631 fmt = '%%s %%-%ds %%-%ds %%s' % (
632 max([len(abs) for (src, abs, rel, exact) in items]),
633 max([len(rel) for (src, abs, rel, exact) in items]))
634 exactly = {True: 'exact', False: ''}
635 for src, abs, rel, exact in items:
636 print fmt % (src, abs, rel, exactly[exact])
634 637
635 638 def diff(ui, repo, *pats, **opts):
636 639 """diff working directory (or selected files)"""
@@ -645,7 +648,7 b' def diff(ui, repo, *pats, **opts):'
645 648 match = util.always
646 649 if pats:
647 650 roots, match, results = makewalk(repo, pats, opts)
648 for src, abs, rel in results:
651 for src, abs, rel, exact in results:
649 652 files.append(abs)
650 653 dodiff(sys.stdout, ui, repo, files, *revs, **{'match': match})
651 654
@@ -687,12 +690,11 b' def export(ui, repo, *changesets, **opts'
687 690
688 691 def forget(ui, repo, *pats, **opts):
689 692 """don't add the specified files on the next commit"""
690 q = dict(zip(pats, pats))
691 693 forget = []
692 for src, abs, rel in walk(repo, pats, opts):
694 for src, abs, rel, exact in walk(repo, pats, opts):
693 695 if repo.dirstate.state(abs) == 'a':
694 696 forget.append(abs)
695 if rel not in q: ui.status('forgetting ', rel, '\n')
697 if not exact: ui.status('forgetting ', rel, '\n')
696 698 repo.forget(forget)
697 699
698 700 def heads(ui, repo, **opts):
@@ -809,7 +811,7 b' def locate(ui, repo, *pats, **opts):'
809 811 end = '\n'
810 812 if opts['print0']: end = '\0'
811 813
812 for src, abs, rel in walk(repo, pats, opts, '(?:.*/|)'):
814 for src, abs, rel, exact in walk(repo, pats, opts, '(?:.*/|)'):
813 815 if repo.dirstate.state(abs) == '?': continue
814 816 if opts['fullpath']:
815 817 ui.write(os.path.join(repo.root, abs), end)
@@ -82,6 +82,6 b' f beans/pinto beans/pinto'
82 82 f beans/turtle beans/turtle
83 83 NOEXIST: No such file or directory
84 84 fifo: unsupported file type (type is fifo)
85 m fenugreek fenugreek
86 m fenugreek fenugreek
87 f new new
85 m fenugreek fenugreek exact
86 m fenugreek fenugreek exact
87 f new new exact
General Comments 0
You need to be logged in to leave comments. Login now