summaryrefslogtreecommitdiff
path: root/git-gui
AgeCommit message (Collapse)AuthorFilesLines
2006-11-07git-gui: Check for fetch or push command failure and denote it.Libravatar Shawn O. Pearce1-12/+25
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Correctly handle CR vs. LF within the console of fetch.Libravatar Shawn O. Pearce1-6/+30
Because the remote end is likely to send us progress meters by resetting each line with a CR (and no LF) we should display those meters by replacing the last line of text with the next line, just like a normal xterm would do. This makes the output of fetch look about the same as if we ran it from within an xterm. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Fix menu item accelerator display on Mac OS X.Libravatar Shawn O. Pearce1-3/+4
Apparently accelerators really only work correctly for function keys (F1-F12) and "Cmd-q". Apparently wish on Mac OS X reports itself as unix and the OS is Darwin, this makes it a little difficult to be sure we are running under Aqua. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Reorganized startup procedure to ensure gitdir is right.Libravatar Shawn O. Pearce1-4/+10
Because we cd after getting the cdup value from Git we can't try to get the gitdir until after we perform the cd, as usually the gitdir is relative to the current working directory. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Worked around environment variable problems on Windows.Libravatar Shawn O. Pearce1-13/+29
Apparently the Cygwin tclsh/wish executables don't pass the environment that they inherited onto any children that they invoke. This causes a problem for some users during 'git fetch' or 'git push' as critical environment variables like GIT_SSH and SSH_AUTH_SOCK aren't available to the git processes. So we work around this by forcing sh to start a login shell, thus reloading the user's environment, then cd to the current directory, and finally start the requested process. Of course this won't correctly handle any transient environment variables that were inherited but were not supplied by the user's login shell. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Started construction of fetch and push operations.Libravatar Shawn O. Pearce1-0/+124
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Misc. nit type of bug fixes.Libravatar Shawn O. Pearce1-7/+29
* Make sure we are in the top level working directory. This way we can access files using their repository path. * Reload the diff viewer if the current file's status has changed; as the diff may now be different. * Correctly handle the 'AD' file state: added but now gone from the working directory. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Implemented amended commits.Libravatar Shawn O. Pearce1-41/+119
Also fixed a bug related that caused a crash if the file currently in the diff viewer is no longer modified after the commit. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Finished commit implementation.Libravatar Shawn O. Pearce1-102/+237
We can now commit any type of commit (initial, normal or merge) using the same techniques as git-commit.sh does for these types of things. If invoked as git-citool we run exit immediately after the commit was finished. If invoked as git-gui then we stay running. Also fixed a bug which caused the commit message buffer to be lost when the application shutdown and restarted. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Verify we should actually perform a commit when asked to do so.Libravatar Shawn O. Pearce1-2/+137
A user shouldn't perform a commit if any of the following are true: * The repository state has changed since the last rescan. * There are no files updated in the index to commit. * There are unmerged stages still in the index. * The commit message has not been provided. * The pre-commit hook is executable and declined. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Corrected keyboard bindings on Windows, improved state management.Libravatar Shawn O. Pearce1-24/+75
When we are refreshing from the index or updating the index we shouldn't let the user cause other index based operations to occur as these would likely conflict with the currently running operations possibly causing some index changes to be lost. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-07git-gui: Fixed UI layout problems on Windows.Libravatar Shawn O. Pearce1-7/+12
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-06git-gui: Additional early feature development.Libravatar Shawn O. Pearce1-56/+214
* Run refresh before diff-index. * Load saved commit message during rescan. * Save current commit message (if any) during quit. * Add Signed-off-by line to commit buffer. * Batch update-index invocations through --stdin. * Better highlight which file is in the diff viewer. * Key bindings for signoff, check-in all and commit. * Improved formatting of status table within source. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2006-11-06git-gui: Initial revision.Libravatar Shawn O. Pearce1-0/+764
This is based on Paul Mackerras' gitool prototype which he offered up to the community earlier in 2006. Its mostly however a rewrite from scratch of a Tcl/Tk based graphical interface for Git and the most common commands users might need to perform. Currently it can display the status of the current repository, and not much else. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>