diff -r 8d7d0bf62f9f -r 22c70c08d4af mercurial/commands.py --- a/mercurial/commands.py Sat Apr 18 15:27:03 2015 +0900 +++ b/mercurial/commands.py Sun Apr 19 21:43:53 2015 -0700 @@ -5837,14 +5837,15 @@ else: show = states[:5] - stat = repo.status(node1, node2, scmutil.match(repo[node2], pats, opts), + m = scmutil.match(repo[node2], pats, opts) + stat = repo.status(node1, node2, m, 'ignored' in show, 'clean' in show, 'unknown' in show, opts.get('subrepos')) changestates = zip(states, 'MAR!?IC', stat) if (opts.get('all') or opts.get('copies') or ui.configbool('ui', 'statuscopies')) and not opts.get('no_status'): - copy = copies.pathcopies(repo[node1], repo[node2]) + copy = copies.pathcopies(repo[node1], repo[node2], m) fm = ui.formatter('status', opts) fmt = '%s' + end