[DEB-682766] Improve tigrc(5) documentation
[tig.git] / NEWS
blob1dc012523e6ed54a7528503e162027a4dadfad67
1 Release notes
2 =============
4 master
5 ------
7 Improvements:
9  - Typing a text in the prompt will be interpreted as a tig command. Prefixing
10    the command with a '!' will execute this system command in an external
11    pager. Entering a single key will execute the corresponding key binding.
12  - Basic support for wrapping long line in pager, diff, and stage views.
13    Enable using: `set wrap-lines = yes`. (GH #2)
14  - User-defined commands prefixed with a '?' means prompt before execution.
15    Example: `bind main B !?git rebase -i %(commit)`
16  - Configure case-insensitive searches using: `set ignore-case = yes`.
17  - Add "deleted mode" line type for better diff coloring.
18  - Open editor when requesting edit action from within a file diff.
19  - Update AX_WITH_CURSES to build under Cygwin.
20  - Improve tigrc(5) documentation. (Debian #682766)
22 Bug fixes:
24  - Fix commit graph regression when a path spec is specified. (GH #53)
25  - Main view: only show staged/unstaged changes for the current branch.
26  - Support submodules created with current version of git. (GH #54)
27  - Fix diff status message for file diffs with no content changes.
29 tig-1.0
30 -------
32 The master repository is git://github.com/jonas/tig.git, and the old
33 master repository (http://jonas.nitro.dk/tig/tig.git) will be retired.
35 Improvements:
37  - Use git-log(1)s default commit ordering. The old behavior can be
38    restored by adding `set commit-order = topo` to ~/.tigrc.
39  - Support staging of single lines. Bound to '1' default. (GH #21)
40  - Use +<lineno> to open the initial view at an arbitrary line. (GH #20)
41  - Add show-notes ~/.tigrc option. Notes are displayed by default.
42  - Support jumping to specific SHAs in the main view.
43  - Decorate replaced commits.
44  - Display line numbers in main view.
45  - Colorize binary diff stats. (GH #17)
46  - Custom colorization of lines matching a string prefix (GH #16).
47    Example configuration: color "Reported-by:" green default
48  - Use git's color settings for the main, status and diff views.
49    Put `set read-git-colors = no` in ~/.tigrc to disable.
50  - Handle editor options with multiple arguments. (GH #12)
51  - Show filename when running tig blame with copy detection. (GH #19)
52  - Use 'source <path>' command to load additional files from ~/.tigrc
53  - User-defined commands prefixed with '@' are run with no console
54    output, e.g.
56         bind generic 3 !@rm sys$command
58  - Make display of space changes togglable in the diff and stage view.
59    Bound to 'W' by default.
60  - Use per-file encoding specified in gitattributes(5) for blobs and
61    unstaged files.
62  - Obsolete commit-encoding option and pass --encoding=UTF-8 to revision
63    commands.
64  - Main view: show uncommitted changes as staged/unstaged commits.
65    Can be disabled by putting `set show-changes = no` in ~/.tigrc.
66  - Add %(prompt) external command variable, which will prompt for the
67    argument value.
68  - Log information about git commands when the TIG_TRACE environment
69    variable is set. Example: `TIG_TRACE=/tmp/tig.log tig`
70  - Branch view: Show the title of the last commit.
71  - Increase the author auto-abbreviation threshold to 10. (GH #49)
72  - For old commits show number of years in relative dates. (GH #50)
74 Bug fixes:
76  - Fix navigation behavior when going from branch to main view. (GH #38)
77  - Fix segfault when sorting the tree view by author name.
78  - Fix diff stat navigation for unmodified files with stat changes.
79  - Show branches/refs which names are a substring of the current branch.
80  - Stage view: fix off-by-one error when jumping to a file in a diff
81    with only one file.
82  - Fix diff-header colorization. (GH #15)
83   
84 tig-0.18
85 --------
87 Incompatibilities:
89  - Remove support for the deprecated TIG_{MAIN,DIFF,LOG,TREE,BLOB}_CMD
90    environment variables.
92 Improvements:
94  - Pressing enter on diff stat file lines will jump to file's diff.
95  - Naïvely color blame IDs to distinguish lines.
96  - Document palette color options used for revision graph and blame IDs.
97  - Add support for blaming diff lines.
98  - Add diff-context option and bindings to increase the diff context in
99    the diff and stage view.
100  - (GH-6) Make blame configurable via extra options passed from the command
101    line and blame-options setting from ~/.tigrc. For example:
102    
103         set blame-options = -C -C -C
105 Bug fixes:
107  - Expand browsing state variables for prompt. (LP #694780, Debian #635546)
108  - Fix segfault when sorting the branch view by author.
109  - Expand %(directory) to . for the root directory. (GH-3)
110  - Accept 'utf-8' for the line-graphics option as indicated in the docs.
111  - Use erasechar() to check for the correct backspace character.
113 tig-0.17
114 --------
116 Improvements:
118  - Start rewrite of the revision graph renderer. Three modes are
119    supported UTF-8, ncurses line graphics, and ASCII. Also, enable
120    revision graph rendering by default.
122 Bug fixes:
124  - Fix ncurses 5.8 issue by passing non-zero column size to newwin().
125  - Fix opening of diffs when browsing branches.
127 tig-0.16.2
128 ----------
130 Bug fixes:
132  - Fix regression causing empty tree view.
133  - Fix set_tabsize() compile error for older versions of ncurses.
135 tig-0.16.1
136 ----------
138 Improvements:
140  - Add scroll-first-col action to jump to the first column. Bound to '|'
141    by default.
142  - Add 'status-untracked-dirs' option to ignore unknown directories
143    contents in the status view. On by default.
145 Bug fixes:
147  - Fix 'tig show <commit>' to show the provided commit.
148  - Fix problem with empty diff views when file specs were passed on the
149    command line.
150  - Fix segfault when starting tig in pager mode.
152 tig-0.16
153 --------
155 Incompatibilities:
157  - Encode everything internally as UTF-8. This can affect performance,
158    but should in general improve handling of character lengths etc.
159    Also, to properly handle UTF-8 environments use ncurses with wide
160    character support.
161  - The use of TIG_{MAIN,DIFF,LOG,TREE,BLOB}_CMD environment variables
162    has been deprecated. To allow configuration of the diff view,
163    TIG_DIFF_OPTS can be used.
165 Improvements:
167  - Plug several memory leaks.
168  - Command line arguments are split into diff, revision, and file
169    arguments and made available as %(diffargs), %(revargs), and
170    %(fileargs). Diff view will limit diffs using %(fileargs).
171  - Status view: update the file variable when a line is selected so
172    %(file) works as expected.
173  - Branch view: add %(branch) symbol providing access to the selected
174    branch.
175  - Branch view: add entry to browse all branches (uses git-log's --all
176    flag).
177  - Abbreviation of author names can now be configured and toggled.
178  - Mark detached heads with [HEAD].
179  - Add support for displaying dates in local time.
181 Bug fixes:
183  - Status view: fix usage from sub directories, which was broken by the
184    changes made to support blame view from sub directories.
185  - Fix text expansion to not truncate long lines
186  - Fix parsing of boolean show-date values.
187  - Fix relative date.
188  - Fix unbind to behave as if the keybinding was never defined.
189  - Fix unbind to also cover built-in run requests.
190  - Fix parsing of unknown keymap names.
191  - Blame view: fix parent blame to detect renames. It uses "previous"
192    line info from the blame porcelain output added in git version 1.6.3.
194 tig-0.15
195 --------
197 Incompatibilities:
199  - Setting the cursor color no longer automatically sets the text to
200    bold. The old 'lazy' behavior was a bug.
201  - Remove check for git-repo-config, which was officially deprecated in
202    git version 1.5.4. The configure script no longer depends on git
203    being installed.
205 Improvements:
207  - Provide the manual as a man page named tigmanual(7).
208  - Add ability to toggle between showing shorter dates (without time
209    info) and relative dates. Use 'D' to toggle between date formats.
210  - Show the active (instead of the default) keybindings in the help
211    view. Furthermore, honor the keymap when suggesting actions in the
212    help messages.
213  - Add branch view for choosing which branch to display in the main
214    view. Bound to 'H' by default.
215  - Tree view: show entry to parent directory ('..') when running from
216    subdirectory.
217  - Tree view: sort entries by name, date or author. Toggling is bound to
218    'i' by default, with 'I' controlling whether or not to sort in
219    ascending order.
220  - Make height of the lower view in a split view configurable by setting
221    the 'split-view-height' variable to a number or a percentage.
222    Defaults to 2/3 of the total view height.
223  - Allow multiple text attributes for color commands:
225         color cursor white blue underline bold
227 Bug fixes:
229  - Blame view: fix loading of blame data when opened from the tree view
230    and CWD is not the repo root. (Debian bug 540766)
231  - Tree view: fix searching.
233 tig-0.14.1
234 ----------
236 Improvements:
238  - Status view: improve "on branch" information inspired by the prompt
239    code in git's bash completion script.
240  - Colors for 256-capable terminals can be specified as colorN.
241  - Entering a number in the prompt will jump to that line number.
242  - Handle core.worktree by setting GIT_DIR and GIT_WORK_TREE.
243  - Make behavior of horizontal scrolling configurable by setting the
244    'horizontal-scroll' variable to a number or a percentage. Defaults to
245    scrolling 50% of the view width.
247 Bug fixes:
249  - Status view: show error when failing to open a file.
250  - Status view: report failures to update a file.
251  - Blame view: fix problem with uninitialized variable.
252  - Blame view: use line number information when loading blame for
253    specific commit.
254  - Fix handling of quoted strings in the config file.
255  - Fix horizontal scrolling glitches.
257 tig-0.14
258 --------
260 Incompatibilities:
262  - The screen-resize action has been deprecated. It had no real use for
263    users and was never meant to be exposed.
264  - The "tree-parent" action was renamed to "parent". Warnings will be
265    emitted for transition.
266  - Remove parsing of deprecated option -S and subcommands log and diff.
267  - The "author" color replaces "main-author". Setting the latter will
268    now set the "author" color.
270 Improvements:
272  - Horizontal scrolling. Bound to Left/Right by default.
273  - Read tigrc(5) options from git configuration files using the syntax:
275         [tig] show-rev-graph = true
276         [tig "color"] cursor = yellow red bold 
277         [tig "bind"] generic = P parent
279  - Tree view: avoid flickering when updating.
280  - Tree view: annotate entries with commit information.
281  - Tree & blob view: open any blob in an editor.
282  - Stage & main view: restore view position when reloading.
283  - Blame view: load blame for parent commit. For merge commits the parent
284    is queried. Bound to ',' by default via the existing "parent" action.
285  - Abbreviate author names to initials when the width of the author column
286    is below 6 characters.
288 Bug fixes:
290  - Tree view: fix memory corruption bug when updating.
291  - Tree view: improve handling of empty trees.
292  - Status view: fix reverting of unmerged files.
293  - Fix regression for non-UTF-8 locales corrupting the view data.
294  - Fix regression parsing multiple spaces in ~/.tigrc.
296 tig-0.13
297 --------
299 Incompatibilities:
301  - Commands from the environment (e.g. TIG_MAIN_CMD) will no longer have
302    access to shell features, such as subshells and variable expansion.
303    The easiest way to upgrade your configuration is to put such commands
304    in a script file or as a git alias.
306 Improvements:
308  - Display repository references in the sorted order: tags, heads,
309    tracked remotes, remotes.
310  - Add bash completion for blame.
311  - Tree view: edit files of the current branch.
312  - Run requests: new identifiers %(directory), %(file), and %(ref)
313  - Improve responsiveness and view loading speed by using select(2).
315 Bug fixes:
317  - Separate blame revision and file argument by "--" to avoid problems.
318  - Main view: fix redrawing of the last commit wrt. the revision graph.
319  - Fix waiting for input after executing a run request in pager mode.
320  - Status & stage view: refuse to open directories and deleted files.
321  - Tree view: show error when requesting blame for all non-file entries.
322  - Do not draw loading views, which are not displayed.
323  - Fix launching of mergetool from a subdirectory.
325 tig-0.12.1
326 ----------
328 Improvements:
330  - Status view: revert uncommitted diff chunks and unstaged files with
331    changes. Bound to '!' by default.
332  - Main view: use --topo-order also when rev-list arguments are given on
333    the command line.
334  - Log view: support for refreshing.
336 Bug fixes:
338  - Status view: use ls-files' --exclude-standard so user specific ignore
339    rules are effective. The option was added in git version 1.5.4.
340  - Stage view: fix assertion failure triggered when updating while
341    status view is not displayed.
342  - Help view: avoid confusion by showing "(no key)" instead of "'?'" for
343    unbound requests.
344  - Reload repository references when refreshing the main (and log) view.
345  - Do not maximize views when refreshing.
347 tig-0.12
348 --------
350 Improvements:
352  - F5 also refreshes the current view.
353  - Allow line graphics to be disabled with new line-graphics option.
354  - Main view: also include the reference names when searching.
355  - Main view: support for refreshing.
356  - Main view: disable boundary commits by default. Use --boundary when
357    they should be shown. (Debian bug 498628)
358  - Stage view: add stage-next action to jump to next diff chunk that can
359    be staged. By default bound to '@'.
360  - Configure: check for the ncurses header files.
361  - Add author-width option to customize the width of the author column.
362    For example, put the following in ~/.tigrc: set author-width = 10
364 Bug fixes:
366  - Fix regression when staging all diff chunks in a section.
367  - Bind the maximize view action to 'O'; it conflicted with the
368    keybinding to launch the merge tool in the status view.
369  - Fix problem with $(cmd) usage in shell code. Some shells (jsh)
370    installed as /bin/sh does not support it.
371  - Do not show incomplete boundary commits when --no-walk is used.
372  - Documentation: Rename gitlink macro to support AsciiDoc 8.2.3.
373  - Ignore pipe reads with errno "Success" reported after a signals,
374    for example when refreshing doing background loading.
376 tig-0.11
377 --------
379 Incompatibilities:
381  - Remove parsing of deprecated options: -g, -l, -d.
382  - The first seen '--' will stop option parsing and is passed to git
383    instead of breaking out of tig's option parsing.
385 New features:
387  - Blame view; bound to 'B' by default, reachable from the command line
388    and the tree, status, and stage views.
389  - Blame/main view: allow display of date, author, and references to be
390    toggled on/off. Bound to 'D', 'A', and 'F' respectively.
391  - Add action to maximize the current view.
393 Improvements:
395  - Show the current branch in the status view.
396  - Show local/light-weight tags.
398 Bug fixes:
400  - Fix regressions for the pager mode.
401  - Fix refreshing of the index with working directory info.
403 tig-0.10.1
404 ----------
406 Improvements:
408  - Status view: detect renamed files and show them with 'R'.
409  - Status view: refresh the index to avoid "empty diffs".
410  - Diff view: make diff headers more verbose to include e.g. committer.
411  - Configure: check for the ncursesw library.
413 Bug fixes:
415  - Fix UTF-8 handling for tag names and commit messages.
416  - Fix the check for git-config(1) in configure to handle the case when
417    git has been installed using a libexecdir which is not in the path.
418  - Fix replacing of SYSCONFDIR when installing from released tarballs.
420 tig-0.10
421 ---------
423 Incompatibilities:
425  - Deprecate most tig specific command line options to make tig more
426    compatible with gitk. The deprecated options are: -g, -l, -d, and -S.
427    Use of any of them will result in a warning being printed to stderr.
428    Instead of '-S', use the new 'status' subcommand.
429  - Make man page building depend on DocBook XSL version >= 1.72.0.
430  - Install man pages in $(prefix)/share/man.
431  - Implement the cherry pick action (bound to 'C') using new support for
432    running external commands. This obsoletes the TIG_CHEERY_PICK
433    environment variable
435 New features:
437  - Add support for binding keys to external commands. To bind '.' to
438    running git-commit(1), add the line: "bind generic . !git commit" to
439    your ~/.tigrc. Each command can have replacement string such as
440    %(commit), %(head), and %(blob), which are substituted before the
441    command is run.
442  - Add system-wide configuration file defaulting to $(prefix)/etc/tigrc.
443  - Add the environment variables TIGRC_USER and TIGRC_SYSTEM to change
444    user and system-wide configuration files, respectively.
446 Improvements:
448  - Main view: color the revision graph.
449  - Main view: show boundary commits; they are marked with '^' in the
450    revision graph.
451  - Tree view: add tree-parent action to jump to view of the parent tree.
452    Bound to ',' by default.
453  - Allow the default terminal colors to be overwritten. To use black
454    text on white, add the line "color default white black" to your
455    ~/.tigrc.
456  - Misc. documentation improvements.
458 Bug fixes:
460  - Use git-diff-index(1) and git-diff-files(1) instead of git-diff(1) to
461    avoid running external diff drivers.
462  - Use --no-color when calling git-log(1).
463  - Fix crash when opening mergetool for lines that are not unmerged.
465 tig-0.9.1
466 ---------
468 Incompatibilities:
470  - Make the clean rule to never remove generated documentation files.
471    Use the distclean rule for accomplishing this.
473 New features:
475  - Add support for cherry-picking commits in the main view to the
476    current branch. Bound to 'C' by default.
478 Improvements:
480  - Add support for launching git-mergetool(1) from the status view.
481    Bound to 'M' by default.
482  - Add support for refreshing/reloading the status view
483  - Detect working trees and disable the status view when it is missing.
485 Bug fixes:
487  - Fix iconv() checking in configure.
488  - Fix editor invocation to make paths relative to the project root.
489  - Fix out-of-range current line when reloading the status view.
490  - Include autoconf files in the tarball generated by `make dist`.
492 tig-0.9
493 -------
495 New features:
497  - Add bash completion script for tig (contrib/tig-completion.bash).
498  - Add optional autoconf-based build infrastructure.
499  - Add stage view for showing changes in the working tree and add
500    support for staging individual diff chunks for commit.
502 Improvements:
504  - Status view: allow all files in a section to be staged for commit.
505  - Status view: Add support for opening files in an editor. Bound to 'e'
506    by default.
507  - Tree view: use a stack for remembering the lines for parent tree.