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.

LINKS

   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