noble (1) git-difftool--helper.1.gz

Provided by: git-cola_4.6.1-1_all bug

NAME

       git-cola - The highly caffeinated Git GUI

SYNOPSIS

       git cola [options] [sub-command]

DESCRIPTION

       Git Cola is a sleek and powerful Git GUI.

OPTIONS

   --amend
       Start git cola in amend mode.

   --prompt
       Prompt for a Git repository.  Defaults to the current directory.

   -r, --repo <path>
       Open the Git repository at <path>.  Defaults to the current directory.

   -s, --status-filter <filter>
       Apply the path filter to the status widget.

   --version
       Print the git cola version and exit.

   -h, --help
       Show usage and optional arguments.

   --help-commands
       Show available sub-commands.

SUB-COMMANDS

   am
       Apply patches.

   archive
       Export tarballs from Git.

   branch
       Create branches.

   browse
       Browse tracked files.

   config
       Configure settings.

   dag
       Start the git dag Git history browser.

   diff
       Diff changed files.

   fetch
       Fetch history from remote repositories.

   grep
       Use git grep to search for content.

   merge
       Merge branches.

   pull
       Fetch and merge remote branches.

   push
       Push branches to remotes.

   rebase
       Start an interactive rebase.

   remote
       Create and edit remotes.

   search
       Search for commits.

   stash
       Stash uncommitted modifications.

   tag
       Create tags.

   version
       Print the git cola version.

CONFIGURE YOUR EDITOR

       The editor used by Ctrl-e is configured from the Preferences screen.

       The following environment variables are consulted when no editor is configured.  If defined, the first of
       these variables is used:

       • GIT_VISUALVISUALGIT_EDITOREDITOR

       The *VISUAL variables are consulted before the *EDITOR variables so that you can  configure  a  graphical
       editor independently of the editor used by the Git CLI.

       Pro  Tip:  Configuring  your editor to gvim -f -p will open multiple tabs when editing files.  gvim -f -o
       uses splits.

       git cola is {vim, emacs, textpad, notepad++}-aware.  When you select a line in the diff or  grep  screens
       and press any of Enter, Ctrl-e, or the Edit button, you are taken to that exact line.

       The editor preference is saved in the gui.editor variable using git config.

       The following are some recommend editor configurations.

       • Neovim + Neovim-Qt

          git config --global core.editor nvim
          git config --global gui.editor 'nvim-qt --nofork'

       • Vim + gvim

          git config --global core.editor vim
          git config --global gui.editor 'gvim -f'

       • Sublime Text

          git config --global gui.editor 'subl --wait'

KEYBOARD SHORTCUTS

       git cola has many useful keyboard shortcuts.

       Many  of  git  cola's  editors  understand  vim-style hotkeys, e.g. {h,j,k,l} for navigating in the diff,
       status, grep, and file browser widgets.

       {d,u} move down/up one half page at a time (similar to vim's  ctrl-{d,u}).   The  space  and  shift-space
       hotkeys are mapped to the same operations.

       Shift-{j,k,d,u,f,b,page-up,page-down,left,right,up,down}  can  be  be  used  in the diff editor to select
       lines while navigating.

       s is a useful hotkey in the diff editor.  It stages/unstages the current selection when  a  selection  is
       present.   When  nothing  is selected, the diff hunk at the current text cursor position is staged.  This
       makes it very easy to review changes by selecting good hunks with s while navigating down and over  hunks
       that are not going to be staged.

       Ctrl-u  in  the  diff  editor  reverts  unstaged  edits,  and respects the selection.  This is useful for
       selectively reverted edits from the worktree.  This same hotkey reverts the entire file  when  used  from
       the status tool.

       Ctrl-s in the diff editor and status tools stages/unstages the entire file.

       You  can  see the available shortcuts by pressing pressing the ? key, choosing Help -> Keyboard shortcuts
       from the main menu, or by consulting the git cola keyboard shortcuts reference.

TOOLS

       The git cola interface is composed of various cooperating tools.  Double-clicking a tool opens it in  its
       own subwindow.  Dragging it around moves and places it within the main window.

       Tools can be hidden and rearranged however you like.  git cola carefully remembers your window layout and
       restores it the next time it is launched.

       The Control-{1, 2, 3, ...} hotkey gives focus to a specific tool.  A hidden tool can be  re-opened  using
       the Tools menu or the Shift+Control-{1, 2, 3, ...} shortcut keys.

       The Diff editor can be focused with Ctrl-j.  The Status tool can be focused with Ctrl-k.  The Commit tool
       can be focused with Ctrl-l.

STATUS

       The Status tool provides a visual analog to the git status command.

       Status displays files that are modified relative to  the  staging  area,  staged  for  the  next  commit,
       unmerged files from an in-progress merge, and files that are untracked to git.

       These are the same categories one sees when running git status on the command line.

       You  can navigate through the list of files using keyboard arrows as well as the ergonomic and vim-like j
       and k shortcut keys.

       There are several convenient ways to interact with files in the Status tool.

       Selecting a file displays its diff in the Diff viewer.  Double-clicking a file stages  its  contents,  as
       does the Ctrl-s shortcut key.

       Ctrl-e opens selected files in the configured editor, and Ctrl-d opens selected files using git difftool

       Additional actions can be performed using the right-click context menu.

   Drag and Drop
       Files can be dragged from the Status tool onto other applications.

       Some  terminals  will  treat  a  drag with multiple files by separating them with newlines, which is less
       amenable for pasting command-line arguments.

       To avoid this issue, hold down Alt / Option when dragging from  the  Status  tool.   The  drag  and  drop
       payload  will no longer contain local file URLs -- it will contain plain text that is amenable for use on
       a command-line.

       Note: if  drag  and  drop  is  not  working  and  you  are  on  Wayland  then  you  may  need  to  export
       QT_QPA_PLATFORM=wayland in your environment.

   Actions
       Clicking the Staged folder shows a diffstat for the index.

       Clicking the Modified folder shows a diffstat for the worktree.

       Clicking individual files sends diffs to the Diff Display.

       Double-clicking individual files adds and removes their content from the index.

       Various  actions  are  available  through  the right-click context menu.  Different actions are available
       depending a file's status.

   Stage Selected
       Add to the staging area using git add Marks unmerged files as resolved.

   Launch Editor
       Launches the configured visual text editor

   Launch Difftool
       Visualize changes using git difftool.

   Revert Unstaged Edits
       Reverts unstaged content by checking out selected paths from the index/staging area

   Revert Uncommitted Edits
       Throws away uncommitted edits

   Unstage Selected
       Remove from the index/staging area with git reset

   Launch Merge Tool
       Resolve conflicts using git mergetool.

   Delete File(s)
       Delete untracked files from the filesystem.

   Add to .gitignore
       Adds untracked files to to the .gitignore file.

DIFF

       The diff viewer/editor displays diffs for selected files.  Additions are shown in green and removals  are
       displayed in light red.  Extraneous whitespace is shown with a pure-red background.

       Right-clicking  in  the diff provides access to additional actions that use either the cursor location or
       text selection.

       The "Copy Diff" action at Alt + Shift + C copies the selected lines to the clipboard. The +, - and ``  ``
       diff line prefixes are stripped from each line when copying diffs using the "Copy Diff" action.

   Staging content for commit
       The  @@  patterns  denote  a  new  diff hunk.  Selecting lines of diff and using the Stage Selected Lines
       command will stage just the selected lines.  Clicking within a diff hunk and selecting  Stage  Diff  Hunk
       stages the entire patch diff hunk.

       The  corresponding opposite commands can be performed on staged files as well, e.g. staged content can be
       selectively removed from the index when we are viewing diffs for staged content.

   Diff Against Commit (Diff Mode)
       Diff Mode allows you to selectively unstage and revert edits from arbitrary commits so that you can bring
       these edits back into your worktree.

       You  can  use  the  diff  editor  to  unstage edits against arbitrary commits by using the Diff > Against
       Commit... (Diff Mode) menu action.

       You can exit Diff Mode by clicking on the red circle-slash icon on the Status widget, by using the Diff >
       Exit Diff mode menu action, or by clicking in an empty area in the Status tool.

COMMIT MESSAGE EDITOR

       The commit message editor is a simple text widget for entering commit messages.

       You can navigate between the Subject and Extended description...  fields using the keyboard arrow keys.

       Pressing enter when inside the Subject field jumps down to the extended description field.

       The Options button menu to the left of the subject field provides access to the additional actions.

       The  Ctrl+i keyboard shortcut adds a standard "Signed-off-by: " line, and Ctrl+Enter creates a new commit
       using the commit message and staged content.

   Sign Off
       The Sign Off button adds a sign-off to the bottom of the commit message:

          Signed-off-by: A. U. Thor <a.u.thor@example.com>

       Invoking this action is equivalent to passing the -s option to git commit.

       Signing-off on commits is a common  practice  in  projects  that  use  Developer  Certificate  of  Origin
       attestations in their contribution process.

   Commit
       The  commit  button runs git commit.  The contents of the commit message editor is provided as the commit
       message.

       Only staged files are included in the commit -- this is the same behavior as running git  commit  on  the
       command-line.

   Line and Column Display
       The  current line and column number is displayed by the editor.  E.g. a 5,0 display means that the cursor
       is located at line five, column zero.

       The display changes colors when lines get too long.  Yellow  indicates  the  safe  boundary  for  sending
       patches to a mailing list while keeping space for inline reply markers.

       Orange indicates that the line is starting to run a bit long and should break soon.

       Red indicates that the line is running up against the standard 80-column limit for commit messages.

       Keeping  commit  messages  less  than 76-characters wide is encouraged.  git log is a great tool but long
       lines mess up its formatting for everyone else, so please be mindful when writing commit messages.

   Amend Last Commit
       Clicking on Amend Last Commit makes git cola amend the previous commit instead of  creating  a  new  one.
       git cola loads the previous commit message into the commit message editor when this option is selected.

       The Status tool will display all of the changes for the amended commit.

   Create Signed Commit
       Tell git commit and git merge to sign commits using GPG.

       Using this option is equivalent to passing the --gpg-sign option to git commit and git merge.

       This option's default value can be configured using the cola.signcommits configuration variable.

   Prepare Commit Message
       The   Commit   ->  Prepare  Commit  Message  action  or  Ctrl-Shift-Return  keyboard  shortcut  runs  the
       cola-prepare-commit-msg hook if it is available in .git/hooks/.  This is a git  cola-specific  hook  that
       takes the same parameters as Git's prepare-commit-msg hook

       The  hook is passed the path to .git/GIT_COLA_MSG as the first argument and the hook is expected to write
       an updated commit message to specified path.  After running this action, the  commit  message  editor  is
       updated with the new commit message.

       To  override  the  default path to this hook set the cola.prepareCommitMessageHook git config variable to
       the path to the hook script.  This is useful  if  you  would  like  to  use  a  common  hook  across  all
       repositories.

BRANCHES

       The  Branches  tool provides a visual tree to navigate branches.  The tree has three main sections: Local
       Branches, Remote Branches and Tags.  Branches are grouped by their name divided by the character /.   For
       example, in a repo with the following list of branches:

          branch/feature/foo
          branch/feature/bar
          branch/doe

       The branches widget will display the following hierarchy:

          branch
              - doe
              + feature
                  - bar
                  - foo

       The  current branch is decorated with a star icon.  If the current branch has commits ahead or behind the
       remote then an up or down arrow will be displayed alongside a number showing the number of commits.

   Actions
       Various actions are available through the right-click context  menu.   Different  actions  are  available
       depending on the selected branch's status.

   Checkout
       The checkout action runs git checkout [<branchname>].

   Merge into current branch
       The merge action runs git merge --no-commit [<branchname>].

   Pull
       The pull action runs git pull --no-ff [<remote>] [<branchname>].

   Push
       The push action runs git push [<remote>] [<branchname>].

   Rename Branch
       The rename branch action runs git branch -M [<branchname>].

   Delete Branch
       The delete branch branch action runs git branch -D [<branchname>].

   Delete Remote Branch
       The remote branch action runs git push --delete [<remote>] [<branchname>].

APPLY PATCHES

       Use the File -> Apply Patches menu item to begin applying patches.

       Dragging  and  dropping  patches  onto  the git cola interface adds the patches to the list of patches to
       apply using git am.

       You can drag either a set of patches or a directory containing patches.  Patches can be sorted  using  in
       the interface and are applied in the same order as is listed in the list.

       When  a  directory is dropped git cola walks the directory tree in search of patches.  git cola sorts the
       list of patches after they have all been found.  This allows you to control the order  in  which  patches
       are applied by placing patch sets into alphanumerically-sorted directories.

CUSTOM WINDOW SETTINGS

       git  cola  remembers  modifications to the layout and arrangement of tools within the git cola interface.
       Changes are saved and restored at application shutdown/startup.

       git cola can be configured to not save custom layouts by disabling the Save Window Settings option in the
       git cola preferences.

DARK MODE AND WINDOW MANAGER THEMES

       Git  Cola  contains  a  default  theme which follows the current Qt style and a handful of built-in color
       themes.  See cola.theme for more details.

       To use icons appropriate for a dark application theme, configure git config --global cola.icontheme  dark
       to use the dark icon theme.  See cola.icontheme for more details.

       On macOS, using the default theme will automatically inherit "Dark Mode" color themes when configured via
       System Preferences.  You will need to configure the dark icon theme as noted  above  when  dark  mode  is
       enabled.

       On  Linux,  you may want Qt to follow the Window manager theme by configuring it to do so using the qt5ct
       Qt5 configuration tool.  Install qt5ct on Debian/Ubuntu systems to make this work.:

          sudo apt install qt5ct

       Once installed, update your ~/.bash_profile to activate qt5ct:

          # Use the style configured using the qt5ct tool
          export QT_QPA_PLATFORMTHEME=qt5ct

       This only work with the default theme.  The other themes replace the color  palette  with  theme-specific
       colors.

       Some  systems  may  require that you override QT_STYLE_OVERRIDE in order to use a dark theme or to better
       interact with the Desktop environment.  Some systems provide a theme that you can install:

          sudo apt-get install adwaita-qt

       You can activate the theme using the following environment variable:

          # Override the default theme to adwaita-dark
          export QT_STYLE_OVERRIDE=adwaita-dark

       QT_STYLE_OVERRIDE may already be set in your Desktop Environment, so check that variable for reference if
       you  get unexpected hangs when launching git-cola or when the default theme does not follow the desktop's
       theme on Linux.

       If you don't want to set this variable globally then  you  can  set  it  when  launching  cola  from  the
       command-line:

          QT_STYLE_OVERRIDE=adwaita-dark git cola

       The following is a user-contributed custom git-cola.desktop file that can be used to launch Git Cola with
       these settings preset for you:

          [Desktop Entry]
          Name=Git Cola (dark)
          Comment=The highly caffeinated Git GUI
          TryExec=git-cola
          Exec=env QT_STYLE_OVERRIDE=adwaita-dark git-cola --prompt --icon-theme dark
          Icon=git-cola
          StartupNotify=true
          Terminal=false
          Type=Application
          Categories=Development;RevisionControl;
          X-KDE-SubstituteUID=false

       You may also want to customize the diff colors when using a dark theme:

          git config --global cola.color.add 86c19f
          git config --global cola.color.remove c07067

       Please see #760 for more details.

   Custom Themes
       To create your own custom theme for Git Cola just create a QSS file and put it in ~/.config/themes/.  You
       can  add  as  many  files  as you want. Each file will become an option in Menu -> File -> Preferences ->
       Appearance -> GUI theme.

       Some examples can be found here Qt Style Sheets Examples.

CONFIGURATION VARIABLES

       These variables can be set using git config or from the settings.

   cola.autocompletepaths
       Set to false to disable auto-completion of filenames in completion widgets.  This can speed up operations
       when working in large repositories.  Defaults to true.

   cola.autoloadCommitTemplate
       Set to true to automatically load the commit template in the commit message editor If the commit.template
       variable has not been configured, raise the corresponding error.  Defaults to false.

   cola.blameviewer
       The command used to blame files.  Defaults to git gui blame.

   cola.blockcursor
       Whether to use a "block" cursor in diff editors. The block cursor is easier to see  compared  to  a  line
       cursor. Set to false to use a thin "line" cursor.  Defaults to true.

   cola.browserdockable
       Whether to create a dock widget with the Browser tool.  Defaults to false to speedup startup time.

   cola.checkconflicts
       Inspect  unmerged  files for conflict markers before staging them.  This feature helps prevent accidental
       staging of unresolved merge conflicts.  Defaults to true.

   cola.defaultrepo
       git cola, when run outside of a Git repository, prompts the user for a repository.  Set  cola.defaultrepo
       to  the  path  of a Git repository to make git cola attempt to use that repository before falling back to
       prompting the user for a repository.

   cola.dictionary
       Specifies an additional dictionary for git cola to use in its spell checker.  This should  be  configured
       to the path of a newline-separated list of words.

       By  default, git cola searches for dict/words and dict/propernames dictionary files in ~/.local/share and
       $XDG_DATA_DIRS.

       If $XDG_DATA_DIRS is undefined or set to an empty value then /usr/local/share and /usr/share are searched
       for dictionary files.

       Dictionary files are newline-separated and contain one word per line.

   cola.expandtab
       Expand  tabs  into  spaces  in  the  commit  message  editor.   When  set to true, git cola will insert a
       configurable number of spaces when tab is pressed.  The number of spaces is determined by  cola.tabwidth.
       Defaults to false.

   cola.gravatar
       Use  the  gravatar.com  service to lookup icons for author emails.  Gravatar icons work by sending an MD5
       hash of an author's email to gravatar.com when  requesting  an  icon.  Warning:  this  feature  can  leak
       information.  Network requests to gravatar.com are disabled when set to false.  Defaults to true.

   cola.fileattributes
       Enables  per-file  gitattributes  encoding  and  binary  file  support.  This tells git cola to honor the
       configured encoding when displaying and applying diffs.

       A .gitattributes file can set the binary attribute in order to  force  specific  untracked  paths  to  be
       treated as binary files when diffing.  Binary files are displayed using a hex-dump display.

          # Treat *.exr files as binary files.
          *.exr binary

   cola.fontdiff
       Specifies the font to use for git cola's diff display.

   cola.hidpi
       Specifies the High DPI displays scale factor. Set 0 to automatically scaled.  Setting value between 0 and
       1 is undefined.  This option requires at least Qt 5.6 to work.  See Qt QT_SCALE_FACTOR documentation  for
       more information.

   cola.icontheme
       Specifies  the  icon  themes  to  use  throughout  git  cola. The theme specified must be the name of the
       subdirectory containing the icons, which in turn must be placed in the inside the main "icons"  directory
       in git cola's installation prefix.

       If unset, or set either "light" or "default", then the default style will be used.  If set to "dark" then
       the built-in "dark" icon theme, which is suitable for a dark window manager theme, will be used.

       If set to an absolute directory path then icons in that directory will be used.  This value can be set to
       multiple values using, git config --add cola.icontheme $theme.

       This  setting  can  be  overridden  by  the  GIT_COLA_ICON_THEME  environment variable, which can specify
       multiple themes using a colon-separated value.

       The icon theme can also be specified by passing --icon-theme=<theme> on the command line, once  for  each
       icon  theme,  in  the  order  that they should be searched.  This can be used to override a subset of the
       icons, and fallback to the built-in icons for the remainder.

   cola.imagediff.[extension]
       Enable image diffs for the specified file  extension.   For  example,  configuring  git  config  --global
       cola.imagediff.svg  false  will disable use of the visual image diff for .svg files in all repos until is
       is explicitly toggled on.  Defaults to true.

   cola.inotify
       Set to false to disable file system change monitoring.  Defaults to true, but also requires either  Linux
       with  inotify  support  or  Windows  with pywin32 installed for file system change monitoring to actually
       function.

   cola.refreshonfocus
       Set to true to automatically refresh when git cola gains focus.  Defaults to false because this can cause
       a pause whenever switching to git cola from another application.

   cola.linebreak
       Whether to automatically break long lines while editing commit messages.  Defaults to true.  This setting
       is configured using the Preferences dialog, but it can be toggled for  one-off  usage  using  the  commit
       message editor's options sub-menu.

   cola.logdate
       Set the default date-time mode for the DAG display. This value is passed to git log --date=<format>.  See
       git log(1) for more details.

   cola.maxrecent
       git cola caps the number of recent repositories to avoid cluttering the  start  and  recent  repositories
       menu.  The maximum number of repositories to remember is controlled by cola.maxrecent and defaults to 8.

   cola.mousezoom
       Controls  whether  zooming  text  using  Ctrl  +  MouseWheel  scroll is enabled.  Set to false to disable
       scrolling with the mouse wheel.  Defaults to true.

   cola.dragencoding
       git cola encodes paths dragged from its widgets into utf-16 when adding them to  the  drag-and-drop  mime
       data  (specifically,  the  text/x-moz-url  entry).   utf-16  is used to make gnome-terminal see the right
       paths, but other terminals may expect a different encoding.  If you are using a terminal that  expects  a
       modern encoding, e.g. terminator, then set this value to utf-8.

   cola.readsize
       git  cola  avoids  reading  large  binary  untracked  files.   The  maximum size to read is controlled by
       cola.readsize and defaults to 2048.

   cola.resizebrowsercolumns
       git cola will automatically resize the file  browser  columns  as  folders  are  expanded/collapsed  when
       cola.resizebrowsercolumns is set to true.

   cola.patchesdirectory
       The  default directory to use when exporting patches. Relative paths are treated as being relative to the
       current repository. Absolute paths are used as-is.  Defaults to patches.

   cola.safemode
       The "Stage" button in the git cola Actions panel stages all files when it is activated and no  files  are
       selected.   This  can  be problematic if it is accidentally triggered after carefully preparing the index
       with staged changes.  "Safe Mode" is enabled by setting cola.safemode to true.  When  enabled,  git  cola
       will do nothing when "Stage" is activated without a selection.  Defaults to false.

   cola.savewindowsettings
       git  cola will remember its window settings when set to true.  Window settings and X11 sessions are saved
       in $HOME/.config/git-cola.

   cola.showpath
       git cola displays the absolute path of the repository in the window  title.   This  can  be  disabled  by
       setting cola.showpath to false.  Defaults to true.

   cola.signcommits
       git cola will sign commits by default when set true. Defaults to false.  See the section below on setting
       up GPG for more details.

   cola.startupmode
       Control how the list of repositories is displayed in the startup dialog.  Set to list to view the list of
       repositories  as  a  list,  or  folder  to view the list of repositories as a collection of folder icons.
       Defaults to list.

   cola.statusindent
       Set to true to indent files in the Status widget.  Files in the Staged, Modified, etc. categories will be
       grouped in a tree-like structure.  Defaults to false.

   cola.statusshowtotals
       Set to true to display files counts in the Status widget's category titles.  Defaults to false.

   cola.tabwidth
       The number of columns occupied by a tab character.  Defaults to 8.

   cola.terminal
       The command to use when launching commands within a graphical terminal.

       cola.terminal  defaults  to  xterm  -e when unset.  e.g. when opening a shell, git cola will run xterm -e
       $SHELL.

       git  cola  has  built-in  support  for  xterm,  gnome-terminal,  konsole.   If   either   gnome-terminal,
       xfce4-terminal,  or  konsole  are  installed then they will be preferred over xterm when cola.terminal is
       unset.

       The table below shows the built-in values that are used for the respective terminal.  You can  force  the
       use of a specific terminal by configuring cola accordingly.

   cola.terminalshellquote
       Some  terminal  require  that  the command string get passed as a string.  For example, xfce4-terminal -e
       "git difftool" requires shell quoting, whereas gnome-terminal -- git difftool does not.

       You should not need to set this variable for the built-in terminals cola knows about --  it  will  behave
       correctly   without   configuration.    For  example,  when  not  configured,  cola  already  knows  that
       xfce4-terminal requires shell quoting.

       This configuration variable is for custom terminals outside of the builtin set.  The  table  below  shows
       the builtin configuration.

          Terminal            cola.terminal           cola.terminalshellquote
          --------            -------------           -----------------------
          gnome-terminal      "gnome-terminal --"     false
          konsole             "konsole -e"            false
          xfce4-terminal      "xfce4-terminal -e"     true
          xterm               "xterm -e"              false

   cola.textwidth
       The number of columns used for line wrapping.  Tabs are counted according to cola.tabwidth.

   cola.theme
       Specifies  the  GUI  theme  to  use throughout git cola. The theme specified must be one of the following
       values:

       • default – default Qt theme, may appear different on various systems

       • flat-dark-blueflat-dark-greenflat-dark-greyflat-dark-redflat-light-blueflat-light-greenflat-light-greyflat-light-red

       If unset, or set to an invalid value, then the default style will be used. The default theme is generated
       by  Qt  internal  engine and should look native but may look noticeably different on different platforms.
       The flat themes on the other hand should look similar (but not identical) on various systems.

       The GUI theme can also be specified by passing --theme=<name> on the command line.

   cola.turbo
       Set to true to enable "turbo" mode.  "Turbo" mode disables some features that can slow things  down  when
       operating  on  huge  repositories.   "Turbo"  mode will skip loading Git commit messages, author details,
       status information, and commit date details in the File Browser tool.  Defaults to false.

   cola.color.text
       The default diff text color, in hexadecimal #RRGGBB notation.  Defaults to "#030303":

          git config cola.color.text '#030303'

   cola.color.add
       The default diff "add" background color, in hexadecimal #RRGGBB notation.  Defaults to "#d2ffe4":

          git config cola.color.add '#d2ffe4'

   cola.color.remove
       The default diff "remove" background color, in hexadecimal #RRGGBB notation.  Defaults to "#fee0e4":

          git config cola.color.remove '#fee0e4'

   cola.color.header
       The default diff header text color, in hexadecimal #RRGGBB notation.  Defaults to "#bbbbbb":

          git config cola.color.header '#bbbbbb'

   commit.cleanup
       Configure whether commit messages should be stripped of whitespace and comments.

       Valid values are strip, whitespace, verbatim, scissors or default.

       The default mode uses the whitespace mode when committing through  Git  Cola  and  the  strip  mode  when
       committing using the git commit command-line.

       • strip  -  Strip  leading  and  trailing  empty  lines,  trailing  whitespace,  commentary  and collapse
         consecutive empty lines.

       • whitespace - Same as strip except # commentary is not removed.   This  is  the  default  behavior  when
         committing through Git Cola.

       • verbatim - Do not change the message at all.

       • scissors  -  Same  as  whitespace  except  that everything from (and including) the line found below is
         truncated, if the message is to be edited.  "#" can be customized with core.commentChar:

            # ------------------------ >8 ------------------------
            Scissor-lines and all following lines are removed.

       Changing the mode to whitespace can be useful when you always want to keep lines that begin with  comment
       character # in your log message, even when committing using the command-line git commit.

       On the contrary, if you always want to always strip comments, even when committing through Git Cola, then
       configure commit.cleanup to strip.

       Please see the git commit cleanup mode documentation for more details.

   core.commentChar
       Commit messages can contain comments that start with this character.  Defaults to #.

       Please see the git config documentation for more details.

   core.hooksPath
       Hooks are programs you can place in a hooks directory to trigger  actions  at  certain  points  in  git’s
       execution. Hooks that don’t have the executable bit set are ignored.

       By  default  the  hooks  directory  is  $GIT_DIR/hooks,  but  that  can be changed via the core.hooksPath
       configuration variable

       The cola-prepare-commit-msg hook functionality and Cola's Git LFS detection honors this configuration.

       Please see the git hooks documentation for more details.

   gui.diffcontext
       The number of diff context lines to display.

   gui.displayuntracked
       git cola avoids showing untracked files when set to false.

   gui.editor
       The default text editor to use is defined in  gui.editor.   The  config  variable  overrides  the  VISUAL
       environment variable.  Defaults to gvim -f -p.

   gui.historybrowser
       The history browser to use when visualizing history.  Defaults to gitk.

   diff.tool
       The default diff tool to use.

   merge.tool
       The default merge tool to use.

   user.email
       Your   email  address  to  be  recorded  in  any  newly  created  commits.   Can  be  overridden  by  the
       'GIT_AUTHOR_EMAIL', 'GIT_COMMITTER_EMAIL', and 'EMAIL' environment variables.

   user.name
       Your full name to be recorded in any newly created commits.  Can be overridden by  the  'GIT_AUTHOR_NAME'
       and 'GIT_COMMITTER_NAME' environment variables.

ENVIRONMENT VARIABLES

   GIT_COLA_ICON_THEME
       When  set  in  the  environment,  GIT_COLA_ICON_THEME overrides the theme specified in the cola.icontheme
       configuration.  Read cola.icontheme for more details.

   GIT_COLA_SCALE
       IMPORTANT:
          GIT_COLA_SCALE should not be used with newer versions of Qt.

          Set QT_AUTO_SCREEN_SCALE_FACTOR to 1 and Qt will automatically scale the interface to the correct size
          based on the display DPI.  This option is also available by setting cola.hidpi configuration.

          See the Qt High DPI documentation for more details.

       git cola can be made to scale its interface for HiDPI displays.  When defined, git cola will scale icons,
       radio buttons, and checkboxes according to the scale factor.  The default value is 1.  A good value is  2
       for high-resolution displays.

       Fonts are not scaled, as their size can already be set in the settings.

   GIT_COLA_TRACE
       When defined, git cola logs git commands to stdout.  When set to full, git cola also logs the exit status
       and output.  When set to trace, git cola logs to the Console widget.

   VISUAL
       Specifies the default editor to use.  This is ignored  when  the  gui.editor  configuration  variable  is
       defined.

LANGUAGE SETTINGS

       git cola automatically detects your language and presents some translations when available.  This may not
       be desired, or you may want git cola to use a specific language.

       You can make git cola  use  an  alternative  language  by  creating  a  ~/.config/git-cola/language  file
       containing the standard two-letter gettext language code, e.g. "en", "de", "ja", "zh", etc.:

          mkdir -p ~/.config/git-cola &&
          echo en >~/.config/git-cola/language

       Alternatively  you may also use LANGUAGE environmental variable to temporarily change git cola's language
       just like any other gettext-based program.  For example to temporarily  change  git  cola's  language  to
       English:

          LANGUAGE=en git cola

       To make git cola use the zh_TW translation with zh_HK, zh, and en as a fallback.:

          LANGUAGE=zh_TW:zh_HK:zh:en git cola

CUSTOM GUI ACTIONS

       git  cola  allows  you  to  define custom GUI actions by setting git config variables.  The "name" of the
       command appears in the "Actions" menu.

   guitool.<name>.cmd
       Specifies the shell command line to execute when the corresponding item of the  Tools  menu  is  invoked.
       This  option is mandatory for every tool. The command is executed from the root of the working directory,
       and in the environment it receives the name of the  tool  as  GIT_GUITOOL,  the  name  of  the  currently
       selected  file  as  FILENAME,  and the name of the current branch as CUR_BRANCH (if the head is detached,
       CUR_BRANCH is empty).

       If <name> contains slashes (/) then the leading part of the name, up until the final  slash,  is  treated
       like a path of sub-menus under which the actions will be created.

       For  example,  configuring  guitool.Commands/Util/echo.cmd  creates  a Commands menu inside the top-level
       Actions menu, a Util menu inside the Commands menu and an echo action inside the Commands sub-menu.

   guitool.<name>.background
       Run the command in the background (similar to editing and difftool actions).  This  avoids  blocking  the
       GUI.  Setting background to true implies noconsole and norescan.

   guitool.<name>.needsfile
       Run the tool only if a diff is selected in the GUI. It guarantees that FILENAME is not empty.

   guitool.<name>.noconsole
       Run the command silently, without creating a window to display its output.

   guitool.<name>.norescan
       Don’t rescan the working directory for changes after the tool finishes execution.

   guitool.<name>.confirm
       Show a confirmation dialog before actually running the tool.

   guitool.<name>.argprompt
       Request  a  string argument from the user, and pass it to the tool through the ARGS environment variable.
       Since requesting an argument implies confirmation, the confirm option has no effect if this  is  enabled.
       If  the  option is set to true, yes, or 1, the dialog uses a built-in generic prompt; otherwise the exact
       value of the variable is used.

   guitool.<name>.revprompt
       Request a single valid revision from the user, and  set  the  REVISION  environment  variable.  In  other
       aspects this option is similar to argprompt, and can be used together with it.

   guitool.<name>.revunmerged
       Show  only  unmerged  branches  in the revprompt sub-dialog. This is useful for tools similar to merge or
       rebase, but not for things like checkout or reset.

   guitool.<name>.title
       Specifies the title to use for the prompt dialog.  Defaults to the tool name.

   guitool.<name>.prompt
       Specifies the general prompt string to display at the top of the dialog, before subsections for argprompt
       and revprompt.  The default value includes the actual command.

   guitool.<name>.shortcut
       Specifies a keyboard shortcut for the custom tool.

       The   value   must   be   a   valid   string   understood   by   the   QAction::setShortcut()  API.   See
       https://doc.qt.io/qt-6/qkeysequence.html#toString for more details about the supported values.

       Avoid creating shortcuts that conflict with existing built-in git cola shortcuts.   Creating  a  conflict
       will result in no action when the shortcut is used.

SETTING UP CREDENTIAL HELPERS

       Git has robust support for automatically handling credentials.

       The recommended approach is to use SSH keys and an SSH agent, but any of the core Git Credentials helpers
       will get used automatically by Git Cola.

       See https://git-scm.com/doc/credential-helpers for more details.

SETTING UP GPG FOR SIGNED COMMITS

       When creating signed commits, gpg will attempt to read your password from the  terminal  from  which  git
       cola  was  launched.   The  way  to  make  this work smoothly is to use a GPG agent so that you can avoid
       needing to re-enter your password every time you commit.

       This also gets you a graphical passphrase prompt instead of getting prompted for  your  password  in  the
       terminal.

   Install gpg-agent and friends
       On Mac OS X, you may need to brew install gpg-agent and install the Mac GPG Suite.

       On Linux use your package manager to install gnupg2, gnupg-agent and pinentry-qt, e.g.:

          sudo apt-get install gnupg2 gnupg-agent pinentry-qt

       On  Linux,  you  should  also  configure Git so that it uses gpg2 (gnupg2), otherwise you will get errors
       mentioning, "unable to open /dev/tty".  Set Git's gpg.program to gpg2:

          git config --global gpg.program gpg2

   Configure gpg-agent and a pin-entry program
       On Mac OS X, edit ~/.gnupg/gpg.conf to include the line,:

          use-agent

       This is typically not needed on Linux, where gpg2 is used, as this is the default value when using gpg2.

       Next, edit ~/.gnupg/gpg-agent.conf to contain a pinentry-program line pointing to  the  pinentry  program
       for your platform.

       The following example ~/.gnupg/gpg-agent.conf shows how to use pinentry-gtk-2 on Linux:

          pinentry-program /usr/bin/pinentry-gtk-2
          default-cache-ttl 3600

       This following example .gnupg/gpg-agent.conf shows how to use MacGPG2's pinentry app on On Mac OS X:

          pinentry-program /usr/local/MacGPG2/libexec/pinentry-mac.app/Contents/MacOS/pinentry-mac
          default-cache-ttl 3600
          enable-ssh-support
          use-standard-socket

       Once this has been set up then you will need to reload your gpg-agent config:

          echo RELOADAGENT | gpg-connect-agent

       If you see the following output:

          OK

       Then the daemon is already running, and you do not need to start it yourself.

       If it is not running, eval the output of gpg-agent --daemon in your shell prior to launching git cola.:

          eval $(gpg-agent --daemon)
          git cola

SHELL COMPLETIONS

       Git  Cola  provides  shell  completions  for  zsh  and bash.  The completion scripts and instructions are
       included in Git Cola's contrib directory.

       • Shell completion scriptsSetup instructions

WINDOWS NOTES

   Git Installation
       If Git is installed in a custom location, e.g. not installed in C:/Git or Program Files, then the path to
       Git  must  be  configured  by  creating  a file in your home directory ~/.config/git-cola/git-bindir that
       points to your git installation, e.g.:

          C:/Tools/Git/bin

   SSH Agents for Key-based Authentication
       You may need to setup ssh-agent in order to use SSH key-based authentication  on  Windows.  It  has  been
       reported  that  starting  OpenSSH  agent  in  Windows  Services  and  adding the key using Powershell are
       necessary in order to get things working.

       Please see the following links for more details.

       https://stackoverflow.com/questions/18683092/how-to-run-ssh-add-on-windows

FIPS SECURITY MODE

       FIPS Security Mode is available in newer versions of Python. These include Python 3.9+  and  the  patched
       Python 3.6 used by CentOS8/RHEL8 (and possibly others).

       Git  Cola  uses  the  hashlib.md5 function and adheres to the FIPS security mode when available. Git Cola
       does not use the MD5 value for security purposes.  MD5 is used only for the purposes of implementing  the
       cola/gravatar.py Gravatar client.

   Git Cola's Git RepositoryPrimary repository <https://gitlab.com/git-cola/git-cola/>_.

       • Mirror repository <https://github.com/git-cola/git-cola/>_.

   Git Cola Homepage
       https://git-cola.gitlab.io/

AUTHOR

       David Aguilar and contributors