Mercurial > hg-stable
diff mercurial/cmdutil.py @ 33879:6f6c87888b22
log: add a "graphwidth" template variable
Wrapping text in templates for 'hg log --graph' can't be done very well,
because the template doesn't know how wide the graph drawing is. The edge
drawing function needs to know the number of lines in the template output, so
we need to also determine how wide that drawing would be before we call the
edgefn or evaluate the template.
This patch makes edgefn compute the graph width and pass it into the template
so that we can do something like this:
COLUMNS=10 hg log --graph --template "{fill(desc, termwidth - graphwidth)}"
@ a a a a
| a a a a
| a a a a
o a a a
|\ a a a
| | a a a
| | a a a
Using extensions to do this would be relatively complicated due to a lack of
hooks in this area of the code.
In the future it may make sense to have a more generic "textwidth" that tells
you how many columns you can expect to fill without causing the terminal to
wrap your output. I'm not sure there are other situations to motivate this yet,
or if it is entirely feasible.
Differential Revision: https://phab.mercurial-scm.org/D360
author | Danny Hooper <hooper@google.com> |
---|---|
date | Tue, 15 Aug 2017 10:15:31 -0700 |
parents | eae63a9e59da |
children | e5d104c35e51 |
line wrap: on
line diff
--- a/mercurial/cmdutil.py Wed Aug 16 10:18:57 2017 +0200 +++ b/mercurial/cmdutil.py Tue Aug 15 10:15:31 2017 -0700 @@ -2652,14 +2652,18 @@ revmatchfn = None if filematcher is not None: revmatchfn = filematcher(ctx.rev()) - displayer.show(ctx, copies=copies, matchfn=revmatchfn) + edges = edgefn(type, char, state, rev, parents) + firstedge = next(edges) + width = firstedge[2] + displayer.show(ctx, copies=copies, matchfn=revmatchfn, + _graphwidth=width) lines = displayer.hunk.pop(rev).split('\n') if not lines[-1]: del lines[-1] displayer.flush(ctx) - edges = edgefn(type, char, lines, state, rev, parents) - for type, char, lines, coldata in edges: + for type, char, width, coldata in itertools.chain([firstedge], edges): graphmod.ascii(ui, state, type, char, lines, coldata) + lines = [] displayer.close() def graphlog(ui, repo, pats, opts):