To Use CommitList Plug-in

The CommitList plug-in is installed by default with EmEditor Professional. This plug-in shows the current changes and the commit history of a Git repo. To use the CommitList plug-in, click CommitList on the Plug-ins bar. Or in the Tools menu, point to Plug-ins, and then click CommitList.

Some features of CommitList require Git to be installed and callable from command prompt with the command git.

Changes sidebar

The plug-in will first check if the current document is in a Git repo. If it is, the repo will be opened and its repo status will be shown. You can click on the Open... button in the sidebar to open a different repo.

Current changes and staged changes are shown in the sidebar. Staged changes are changes that were added to the index. All other changes to the working directory are shown in the changes list.

Right-clicking on a changed file in the sidebar will show a menu with commands for that changed file. These are the options in this menu.

  • View Changes shows a comparision in the editor to show what changed to the file. Specifically, the versions of the file being compared are the last commit and the index version for staged files or the index version and worktree version for unstaged files.

  • Open File opens that file in the editor.

  • Stage and Unstage are equivalent to the commands git add and git reset.

  • Undo Changes can be selected on unstaged files. It calls git checkout to overwrite the file with the contents in the index. Untracked files are deleted.

  • If a submodule is listed, Update Submodule will call git submodule update --init to update the files in the submodule to its current HEAD.

  • Refresh will refresh the changed files list.

CommitList monitors the file system so that if a file in the repo directory was modified by an external program, the sidebar is refreshed.

The Pull button pulls changes from the remote to the local repo. Push sends local changes to the remote repo. If the current branch is not associated with an upstream branch, the upstream branch will be created before pushing changes to it. These commands print a message to the status bar on completion.

The Pull and Push buttons may also display a number to indicate the number of commits behind or ahead of the upstream branch. "Pull (1)" means that there is 1 commit to pull and "Push (1)" means that there is 1 commit to push. The Autofetch option in the menu is useful for updating these numbers periodically.

You can click on the > button to access more commands.

  • Refresh refreshes the changed files list.

  • Command Output shows the output of previous commands.

  • The Status command prints the output of git status.

  • The Fetch command updates your remote-tracking branches.

  • Open Repo Folder opens the repo folder in File Explorer.

  • If the current branch has an upstream branch, Open Repo Website opens the project's source control and collaboration website, like GitHub, in the web browser.

  • If Autofetch is enabled, git fetch is called every 3 minutes.

  • Help opens this page.

You can change the current branch with the dropdown menu. Changing the branch is equivalent to the command git checkout branch. Conflicting changes will prevent you from checking out a branch.

The edit control below the branch dropdown is where you can write a commit message. Click on Commit Staged/Commit All to either commit the staged changes or to stage all changes and commit. The commit will be made to the currently selected branch.

Commit list

Click on the Commit List button to view the commit history. When a commit is selected, the right panel displays the commit details and the list of files changed on this commit. Right-click on a file in the list and select Compare with Previous to see what changed to the file on this commit.

In the commit list, you can right-click on a commit and select Copy to copy the commit details. Browse Files At Commit will show the directory tree when the commit was made. And Compare Commits will show you the differences between two commits.

You can checkout the commit with Checkout (--detach), which creates a detached HEAD. If you want to create a new branch from the commit, select Create New Branch....

You can filter the list by clicking on Filter History…. Enter the Filter String, select a Filter By option, then click Filter. The commit list now only shows commits that match the filter. The Cancel Filter button next to the Filter History… button cancels the filter.

The left panel shows a list of branches in the repo. The context menu shows commands relating to branches.

  • View Branch: Show the list of commits for that branch.

  • Compare Branches: When two branches are selected, you can compare the files between those branches.

  • Refresh: Refreshes the information displayed in the CommitList bar

  • Checkout Branch: Switch to the branch

  • Create New Branch...: Create new branch from the selected branch and checkout the new branch.

  • Delete Branch: Delete the selected branch

  • Delete Remote Branch: Deletes the remote branch that is tracked by the branch. (Calls the command git push -v <upstream> --delete <branch>)

If a file that is in the current repo is opened in the editor, the View History For Current Document button can be selected. It lists any commits that include changes to the current file. Right-clicking on a commit will show four options. Show Commit jumps to that commit in the main commit list. Compare with Previous compares the file with its previous revision. Compare File at Commits compares the file at two different commits. Compare with File in Working Tree compares the file at the selected commit and the work tree version.

Tips

  • Press the F6 key or ESC key to set the keyboard focus back to the editor.