summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
* Do not attempt to access literal dirname "GIT_OBJECT_DIRECTORY".Tommi Virtanen2005-11-301-1/+1
| | | | | | | Dereference the environment variable before using it. Signed-off-by: Tommi Virtanen <tv@inoi.fi> Signed-off-by: Junio C Hamano <junkio@cox.net>
* git-diff: do not turn off -p/-M with any diff options.Junio C Hamano2005-11-291-2/+15
| | | | | | | | | | | | When the user gives a diff option (e.g. --cached) to "git diff", we turned off the built-in default option -p, which is usually not what user wants to see. This commit makes lack of --name-status, --name-only nor -r to add -p, and lack of -B*, -C* nor -M* to add -M to the flags given to the underlying diff. Signed-off-by: Junio C Hamano <junkio@cox.net>
* Merge http://www.kernel.org/pub/scm/gitk/gitkJunio C Hamano2005-11-291-54/+88
|\
| * gitk: Add a preferences dialog with some basic stuffPaul Mackerras2005-11-301-54/+88
| | | | | | | | | | | | | | There is a lot more that could be put in, such as a selector for the font family etc., but this is a start. Signed-off-by: Paul Mackerras <paulus@samba.org>
* | [PATCH] Add tests for git-mv in subdirectoriesAlex Riesen2005-11-291-0/+27
| | | | | | | | | | | | | | | | | | | | | | | | Junio C Hamano, Sat, Nov 26, 2005 03:45:52 +0100: > I haven't seriously used git-mv myself, so > somebody needs to test it, and if it actually works and Ack on > it, please. It actually works in subdirs. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | [PATCH] Make git-mv work in subdirectories, tooJohannes Schindelin2005-11-291-9/+3
| | | | | | | | | | | | | | | | | | | | | | | | Turns out, all git programs git-mv uses are capable of operating in a subdirectory just fine. So don't complain about it. [jc: I think that sounds sane. You need to grab the exit status from `git-rev-parse --git-dir`, which I added. Alex Riesen says this worked fine.] Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | SVN import: Use one log callMatthias Urlichs2005-11-292-29/+21
| | | | | | | | | | | | | | | | | | | | | | | | | | One "svn log" (or its equivalent) per revision adds delay and server load. Instead, open two SVN connections -- one for the log, and one for the files. Positive side effect: Only those log entries which actually contain data are committed => no more empty commits. Also, change the "-l" option to set the maximum revision to be pulled, not the number of revisions. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Fix typos and minor format issues.jdl@freescale.com2005-11-291-7/+7
| | | | | | | | | | Signed-off-by: Jon Loeliger <jdl@freescale.com> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | http-push cleanupNick Hengeveld2005-11-291-2/+3
| | | | | | | | | | | | | | | | | | The malloc patch from Jan Andres fixed the problem that was causing a segfault when freeing the lock token, and Johannes Schindelin found and fixed a problem when no URL is specified on the command line. Signed-off-by: Nick Hengeveld <nickh@reactrix.com> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-clone --shared should imply --localPavel Roskin2005-11-281-1/+1
| | | | | | | | | | | | | | | | | | The "--shared" option to git-clone is silently ignored if "--local" is not specified. The manual doesn't mention such dependency. Make "--shared" imply "--local". Signed-off-by: Pavel Roskin <proski@gnu.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | write_name_quoted(): make one of the path a counted string.Junio C Hamano2005-11-284-16/+29
| | | | | | | | | | | | This is to prepare for ls-tree updates. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Documentation: Describe merge operation a bit better.Junio C Hamano2005-11-281-0/+95
| | | | | | | | | | | | | | | | In git-merge documentation, add a section to describe what happens to the index and working tree during merge, and what their cleanliness requirements are before the merge. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Fix typo in http-push.cJan Andres2005-11-281-1/+1
| | | | | | | | | | | | Typo resulted in accessing past the beginning of a string causing segfaults. [jc: signoffs?]
* | name-rev: fix parent counting.Junio C Hamano2005-11-281-2/+2
| | | | | | | | | | | | | | Noticed by linux@horizon.com. The first merge parent (typically "our branch") is ^1, not ^0, and the first other branch is ^2. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | rebase: one safety net, one bugfix and one optimization.Junio C Hamano2005-11-281-1/+27
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When a .dotest from a previously failed rebase or patch application exists, rebase got confused and tried to apply mixture of what was already there and what is being rebased. Check the existence of the directory and barf. It failed with an mysterious "fatal: cannot read mbox" message if the branch being rebased is fully in sync with the base. Also if the branch is a proper descendant of the base, there is no need to run rebase logic. Prevent these from happening by checking where the merge-base is. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Merge http://www.kernel.org/pub/scm/gitk/gitkJunio C Hamano2005-11-281-41/+35
|\ \ | |/
| * [PATCH] gitk: Use i18n.commitencoding configuration item.Junio C Hamano2005-11-281-1/+8
| | | | | | | | | | | | | | | | Hardcoding "utf-8" in the script breaks projects that use local encoding, so allow setting i18n.commitEncoding. Signed-off-by: Junio C Hamano <junkio@cox.net> Signed-off-by: Paul Mackerras <paulus@samba.org>
| * gitk: Fix diff this->selected and selected->this functionsPaul Mackerras2005-11-281-12/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The change in 8b7e5d76e836396a097bb6f61cf930ea872a7bd3, which makes a couple of git-diff-tree calls supply only one id rather than two, fixes the display when showing what a single commit did with dense revlists, but broke the diff this->selected and diff selected->this right-click menu functions. Yann Dirson pointed this out and had a patch that fixed the diff menu functions by passing a "singlecommit" flag around. This fixes it a bit differently, by making the ids and diffids variables be either a single id, in the case of showing what a commit did, or {oldid newid}, in the case of the diff menu functions. That way we can just pass $ids to git-diff-tree as is. Most of the changes in fact are just reversing the order of ids in $ids and $diffids, because they used to be {child parent}, but git-diff-tree requires old id before new id. Signed-off-by: Paul Mackerras <paulus@samba.org>
* | git-mv: quote $src in regexp properly.Junio C Hamano2005-11-281-1/+1
| | | | | | | | | | | | Noticed and fixed by Matthias Urlichs and Josef Weidendorfer. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | config.c: constness tightening to avoid compilation warning.Junio C Hamano2005-11-281-1/+1
| | | | | | | | Signed-off-by: Junio C Hamano <junkio@cox.net>
* | mailinfo: Do not use -u=<encoding>; say --encoding=<encoding>Junio C Hamano2005-11-282-5/+12
| | | | | | | | | | | | | | | | | | | | Specifying the value for a single letter, single dash option parameter with equal sign looked funny, and more importantly calling the flag to override encoding from utf-8 to something else "-u" (obviously abbreviated from "utf-8") did not make any sense. So spell it out. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | mailinfo: Use i18n.commitencodingJunio C Hamano2005-11-271-8/+9
| | | | | | | | | | | | | | | | This uses i18n.commitencoding configuration item to pick up the default commit encoding for the repository when converting form e-mail encoding to commit encoding (the default is utf8). Signed-off-by: Junio C Hamano <junkio@cox.net>
* | mailinfo: allow -u to fall back on latin1 to utf8 conversion.Junio C Hamano2005-11-271-24/+35
| | | | | | | | | | | | | | | | | | | | | | When the message body does not identify what encoding it is in, -u assumes it is in latin-1 and converts it to utf8, which is the recommended encoding for git commit log messages. With -u=<encoding>, the conversion is made into the specified one, instead of utf8, to allow project-local policies. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Introduce i18n.commitencoding.Junio C Hamano2005-11-273-0/+9
| | | | | | | | | | | | | | | | This is to hold what the project-local rule as to the charset/encoding for the commit log message is. Lack of it defaults to utf-8. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Fix gitk this->selected diffsYann Dirson2005-11-271-21/+32
| | | | | | | | | | | | | | | | | | | | | | | | | | | | The change made in 8b7e5d76e836396a097bb6f61cf930ea872a7bd3 to accomodate dense revlists in single-commit diffs has broken computing of diffs between arbitrary trees, which does need to consider two commit ids. This patch changes the two git-diff-tree calls to get the necessary two ids in this case. It does so by propagating a "singlecommit" flag through all functions involved via an additional argument. Signed-off-by: Yann Dirson <ydirson@altern.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Merge http://www.kernel.org/pub/scm/gitk/gitkJunio C Hamano2005-11-271-43/+45
|\ \ | |/
| * [PATCH] gitk: UTF-8 supportPavel Roskin2005-11-231-2/+3
| | | | | | | | | | | | | | | | Add gitencoding variable and set it to "utf-8". Use it for converting git-rev-list output. Signed-off-by: Pavel Roskin <proski@gnu.org> Signed-off-by: Paul Mackerras <paulus@samba.org>
| * [PATCH] gitk: put braces around exprsJeff Hobbs2005-11-231-41/+42
| | | | | | | | | | | | This braces all exprs. It just seemed to be a few that were missed. Signed-off-by: Paul Mackerras <paulus@samba.org>
* | git-mv: follow -k request even on failing renamesJosef Weidendorfer2005-11-271-0/+5
| | | | | | | | | | | | | | | | | | | | | | | | -k requests to keep running on an error condition. Previously, git-mv stopped on failing renames even with -k. There are some error conditions which are not checked in the first phase of git-mv, eg. 'permission denied'. Still, option -k should work. Signed-off-by: Josef Weidendorfer <Josef.Weidendorfer@gmx.de> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Small fixes in Documentation/git-mv.txtJosef Weidendorfer2005-11-271-4/+4
| | | | | | | | | | | | | | | | | | The two synopsis lines have to be prefixed with a space so that asciidoc inserts a line break inbetween for the manual page. Signed-off-by: Josef Weidendorfer <Josef.Weidendorfer@gmx.de> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-mv: fully detect 'directory moved into itself'Josef Weidendorfer2005-11-271-1/+1
| | | | | | | | | | | | | | | | | | This gives a better error message when trying to move a directory into some subdirectory of itself; ie. no real bug fix: renaming already failed before, but with a strange "invalid argument". Signed-off-by: Josef Weidendorfer <Josef.Weidendorfer@gmx.de> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-mv: keep git index consistent with file system on failed renameJosef Weidendorfer2005-11-271-2/+10
| | | | | | | | | | | | | | | | | | | | When doing multiple renames, and a rename in the middle fails, git-mv did not store the successful renames in the git index; this is fixed by delaying the error message on a failed rename to after the git updating. Signed-off-by: Josef Weidendorfer <Josef.Weidendorfer@gmx.de> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-mv: shrink usage, no usage on errorJosef Weidendorfer2005-11-271-27/+19
| | | | | | | | | | | | | | | | | | | | | | Small fixes to be consistent with other git scripts: - usage message is only about options and arguments - on error, exit(1) without the usage message Additionally, "beautifies" output with -n a little bit Signed-off-by: Josef Weidendorfer <Josef.Weidendorfer@gmx.de> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | setup_git_directory(): check repository format version.Junio C Hamano2005-11-271-0/+1
| | | | | | | | | | | | | | | | After figuring out the GIT_DIR location, make sure the repository is of the right vintage, by calling check_repository_format(). . Signed-off-by: Junio C Hamano <junkio@cox.net>
* | init-db: check template and repository format.Junio C Hamano2005-11-273-42/+64
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This makes init-db repository version aware. It checks if an existing config file says the repository being reinitialized is of a wrong version and aborts before doing further harm. When copying the templates, it makes sure the they are of the right repository format version. Otherwise the templates are ignored with an warning message. It copies the templates before creating the HEAD, and if the config file is copied from the template directory, reads it, primarily to pick up the value of core.symrefsonly. It changes the way the result of the filemode reliability test is written to the configuration file using git_config_set(). The test is done even if the config file was copied from the templates. And finally, our own repository format version is written to the config file. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Check repository format version in enter_repo().Junio C Hamano2005-11-271-0/+1
| | | | | | | | | | | | | | | | | | After daemon, upload-pack and receive-pack find out where the git directory is and chdir() there, make sure that repository is in a format we understand, after putenv("GIT_DIR=.") so that it knows to pick up the configuration file from there. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Repository format version check.Junio C Hamano2005-11-273-0/+22
| | | | | | | | | | | | | | This adds the repository format version code, first done by Martin Atukunda. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | format-patch: output filename reported to stdout verbatim.Junio C Hamano2005-11-261-2/+2
| | | | | | | | | | | | | | | | Prepending asterisk to the output was just adding noise, and making scripts like proposed git-send-mail by Andreas Ericsson do unnecessary work. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | name-rev: fix off-by-one error in --stdin.Junio C Hamano2005-11-251-4/+3
| | | | | | | | | | | | | | | | | | It dropped the last hexdigit in the object name. [jc: Noticed and patch supplied by ALASCM, reworked to apply at the right place by me] Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-mv is not able to handle big directoriesAlexander Litvinov2005-11-251-9/+22
| | | | | | | | | | | | | | | | | | Use update-index --stdin to handle large number of files without breaking exec() argument storage limit. [jc: with minor cleanup from the version posted on the list] Signed-off-by: Junio C Hamano <junkio@cox.net>
* | shell.c: complain on insufficient arguments.Junio C Hamano2005-11-251-2/+1
| | | | | | | | | | | | Originally noticed by Tommi Virtanen, but done slightly differently. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-sh-setup: move the repository check to a core program.Junio C Hamano2005-11-251-7/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Any core commands that use setup_git_directory() now check if given GIT_DIR is really a valid repository, so the same check in git-sh-setup can use it without reimplementing it in shell. This commit changes git-sh-setup to use git-var command for that, although any other commands would do. Note that we export GIT_DIR explicitly when calling git-var; without it, the caller of this script would use GIT_DIR that we return (which is to assume ./.git unless the caller has it elsewhere) while git-var would go up to find a .git directory in our parent directories, which would be checking a different directory from what our callers will be using. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | setup_git_directory: make sure GIT_DIR is a valid repository.Junio C Hamano2005-11-251-5/+37
| | | | | | | | | | | | | | | | | | | | | | setup_git_directory() always trusted what the user told where GIT_DIR was, and assumed that is a valid .git/ directory. This commit changes it to at least do the same level validation as is_toplevel_directory() does -- has refs/, has objects/ unless GIT_OBJECT_DIRECTORY is set, and has valid HEAD symlink or symref. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-var: make it work in subdirectory.Junio C Hamano2005-11-251-0/+2
| | | | | | | | | | | | | | Use setup_git_directory() so that it can find its .git directory. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | git-sh-setup: die if outside git repository.Junio C Hamano2005-11-2526-31/+34
| | | | | | | | | | | | | | | | Now all the users of this script detect its exit status and die, complaining that it is outside git repository. So move the code that dies from all callers to git-sh-setup script. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | parse-remote and ls-remote clean-up.Junio C Hamano2005-11-252-2/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | There is no reason to use git-sh-setup from git-ls-remote. git-parse-remote can help the caller to use .git/remotes shortcut if it is run inside a git repository, but can still be useful outside a git repositoryas long as the caller does not use any shortcut. Use "git-rev-parse --git-dir" to figure out where the GIT_DIR is, instead of using git-sh-setup. This also makes "git-ls-remote origin" to work from inside a subdirectory of a git managed repository as a side effect. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Prevent "git-commit -a path1 path2..."Junio C Hamano2005-11-251-1/+4
| | | | | | | | | | | | | | When you want to create a partial commit, giving -a by mistake would ignore the given path. Prevent it. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | config.c: avoid shadowing global.Junio C Hamano2005-11-251-5/+5
| | | | | | | | | | | | | | This is purely cosmetic, but avoid shadowing "FILE *config_file" global in git_config_set_multivar() function. Signed-off-by: Junio C Hamano <junkio@cox.net>
* | Fix a warning about unused value.YOSHIFUJI Hideaki / 吉藤英明2005-11-251-1/+1
| | | | | | | | | | | | | | | | Fix a warning: git.c:276: warning: value computed is not used Signed-off-by: YOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
* | cvsimport: Don't let local settings hinder cvs user-migration.Andreas Ericsson2005-11-251-1/+1
| | | | | | | | | | | | | | Avoid this by passing "--norc" to cvsps. Signed-off-by: Andreas Ericsson <ae@op5.se> Signed-off-by: Junio C Hamano <junkio@cox.net>