# HG changeset patch # User Yuya Nishihara # Date 2015-04-05 04:16:46 # Node ID c560d8c687916cb70a6d54c2c9ddcb5c9e457be2 # Parent 11e8fec00234922bec35808f45c58d444b5da441 cat: disable optimization of single file case for workingctx It crashes because workingctx has no manifest. diff --git a/mercurial/cmdutil.py b/mercurial/cmdutil.py --- a/mercurial/cmdutil.py +++ b/mercurial/cmdutil.py @@ -2403,7 +2403,7 @@ def cat(ui, repo, ctx, matcher, prefix, file = matcher.files()[0] mf = repo.manifest mfnode = ctx.manifestnode() - if mf.find(mfnode, file)[0]: + if mfnode and mf.find(mfnode, file)[0]: write(file) return 0 diff --git a/tests/test-cat.t b/tests/test-cat.t --- a/tests/test-cat.t +++ b/tests/test-cat.t @@ -63,3 +63,8 @@ Test fileset tmp/h_45116003780e tmp/r_2 +Test working directory + + $ echo b-wdir > b + $ hg cat -r 'wdir()' b + b-wdir