On Wed, May 13, 2009 at 10:29:40PM -0700, Junio C Hamano wrote: > Junio C Hamano <gitster@xxxxxxxxx> writes: > > > Caleb Cushing <xenoterracide@xxxxxxxxx> writes: > > > >> On Wed, May 13, 2009 at 2:37 PM, Junio C Hamano <gitster@xxxxxxxxx> wrote: > >>> Thanks for saying this concisely, and saving me from repeating this. > >> > >> I just don't think one should have to explicitly set something to shut > >> warnings up. defaults are there for a reason. next thing you know it's > >> going to ask me if I'd like to continue, and then it will ask me to > >> press n for next. > >> > >> Why even have them? > > > > Why do you waste other people's time after repeatedly told this was > > discussed to death and everything is recoded in the list archive? > > You know what is most frustrating for me with this whole thing? > > As you might have guessed already, I am one of the oldest users of git, am > accustomed to the way "matching push" works, and I like it as a sensible > default behaviour for _my workflow_. If I, Linus and you were the only > git users, there won't be these half-page-full of warning messages. > > But there are others, and one of them was motivated enough to write a > patch series to introduce push.default that allows a setting that may be > more suitable than 'matching' in certain workflows, even though I may not > ever use that workflow in my projects myself. This early vaccination > approach was the least evil solution proposed back then (which I think was > modelled after the already in-progress "deny git push from updating the > current branch" topic), and you were not around to know that I even toned > down the series not to make it too strongly suggest that the default will > change. > > No, "you were not around" part is not what is frustrating. What is > frustrating is that the original author who felt strongly enough against > 'matching' default to write the patch is not defending the change in this > thread, and I have to spend time writing responses like this that I > otherwise could be using for something else to improve the project with. I am sorry to be the primary source of your frustration. Anyway, to summarize the old thread quickly from my point of view: "git push" is a very dangerous operation if you are using multiple remotes, and you are not the owner/maintaner of all of them. A very common workflow where this is wrong is when using a shared pushable repo. Advanced users can configure push as they want, the default is most important for new users. From the discussions we had it seems that it is not possible to make a default that works well for different workflows, so I argue we should make the least dangerous default the default. I would like to change the default behaviour of "git push" to do nothing at all, and to give a short message hinting at how to configure it if you invoke git push without any arguments. The current state of git as of 1.6.3.1, to push matching, but to complain, is not a good terminal state I think. I have also noticed that printing long warnings (10+ lines) is not helpful for people, they really need to be as short as possible or they will not be read or understood. So, something like this as the next stage perhaps (this is not complete, man-pages and some tests should be updated as well): --8<-- diff --git a/builtin-push.c b/builtin-push.c index 2eabcd3..80c81ea 100644 --- a/builtin-push.c +++ b/builtin-push.c @@ -65,18 +65,8 @@ static void setup_push_tracking(void) } static const char *warn_unconfigured_push_msg[] = { - "You did not specify any refspecs to push, and the current remote", - "has not configured any push refspecs. The default action in this", - "case is to push all matching refspecs, that is, all branches", - "that exist both locally and remotely will be updated. This may", - "not necessarily be what you want to happen.", - "", - "You can specify what action you want to take in this case, and", - "avoid seeing this message again, by configuring 'push.default' to:", - " 'nothing' : Do not push anything", - " 'matching' : Push all matching branches (default)", - " 'tracking' : Push the current branch to whatever it is tracking", - " 'current' : Push the current branch" + "Nothing to push, and push.default is not configured.", + "See git-push(1) and git-config(1) for details." }; static void warn_unconfigured_push(void) @@ -92,7 +82,8 @@ static void setup_default_push_refspecs(void) switch (push_default) { case PUSH_DEFAULT_UNSPECIFIED: warn_unconfigured_push(); - /* fallthrough */ + exit(EXIT_FAILURE); + break; case PUSH_DEFAULT_MATCHING: add_refspec(":"); --8<-- - Finn Arne -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html