* [PATCH] "not uptodate" changed to "has local changes"
@ 2008-05-03 16:59 Tim Harper
2008-05-06 13:31 ` Mike Ralphson
0 siblings, 1 reply; 24+ messages in thread
From: Tim Harper @ 2008-05-03 16:59 UTC (permalink / raw)
To: git; +Cc: Tim Harper
When doing a merge, the message says "file.txt: needs update", or "file.txt: not uptodate, cannot merge". While internally 'uptodate' makes sense, from the outside it's a mystery.
This patch will make git a little more human friendly, reporting "file.txt: has local changes".
---
read-cache.c | 2 +-
unpack-trees.c | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/read-cache.c b/read-cache.c
index a92b25b..e890b27 100644
--- a/read-cache.c
+++ b/read-cache.c
@@ -999,7 +999,7 @@ int refresh_index(struct index_state *istate, unsigned int flags, const char **p
}
if (quiet)
continue;
- printf("%s: needs update\n", ce->name);
+ printf("%s: has local changes\n", ce->name);
has_errors = 1;
continue;
}
diff --git a/unpack-trees.c b/unpack-trees.c
index a59f475..1d67e08 100644
--- a/unpack-trees.c
+++ b/unpack-trees.c
@@ -427,7 +427,7 @@ static int verify_uptodate(struct cache_entry *ce,
if (errno == ENOENT)
return 0;
return o->gently ? -1 :
- error("Entry '%s' not uptodate. Cannot merge.", ce->name);
+ error("Entry '%s' has local changes. Cannot merge.", ce->name);
}
static void invalidate_ce_path(struct cache_entry *ce, struct unpack_trees_options *o)
--
1.5.5.1
^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-03 16:59 [PATCH] "not uptodate" changed to "has local changes" Tim Harper
@ 2008-05-06 13:31 ` Mike Ralphson
2008-05-16 2:14 ` André Goddard Rosa
0 siblings, 1 reply; 24+ messages in thread
From: Mike Ralphson @ 2008-05-06 13:31 UTC (permalink / raw)
To: Tim Harper; +Cc: git
2008/5/3 Tim Harper <timcharper@gmail.com>:
> When doing a merge, the message says "file.txt: needs update", or "file.txt: not uptodate, cannot merge". While internally 'uptodate' makes sense, from the outside it's a mystery.
>
> This patch will make git a little more human friendly, reporting "file.txt: has local changes".
Documentation/git-checkout.txt should also change in this case,
otherwise users will see different output to that described and
possibly get confused if following along with the examples.
Mike
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-06 13:31 ` Mike Ralphson
@ 2008-05-16 2:14 ` André Goddard Rosa
2008-05-16 10:25 ` Johannes Schindelin
0 siblings, 1 reply; 24+ messages in thread
From: André Goddard Rosa @ 2008-05-16 2:14 UTC (permalink / raw)
To: Mike Ralphson; +Cc: Tim Harper, git
>> This patch will make git a little more human friendly, reporting "file.txt: has local changes".
>
> Documentation/git-checkout.txt should also change in this case,
> otherwise users will see different output to that described and
> possibly get confused if following along with the examples.
>
I like the idea too.
---
[PATCH] "not uptodate" changed to "has local changes"
Use more straightforward message for regular user.
Signed-off-by: Andre Goddard Rosa <andre.goddard@gmail.com>
diff --git a/Documentation/git-checkout.txt b/Documentation/git-checkout.txt
index a644173..624dea6 100644
--- a/Documentation/git-checkout.txt
+++ b/Documentation/git-checkout.txt
@@ -168,7 +168,7 @@ the above checkout would fail like this:
+
------------
$ git checkout mytopic
-fatal: Entry 'frotz' not uptodate. Cannot merge.
+fatal: Entry 'frotz' has local changes. Cannot merge.
------------
+
You can give the `-m` flag to the command, which would try a
^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-16 2:14 ` André Goddard Rosa
@ 2008-05-16 10:25 ` Johannes Schindelin
2008-05-16 11:02 ` Holger Schurig
2008-05-16 17:12 ` Kevin Ballard
0 siblings, 2 replies; 24+ messages in thread
From: Johannes Schindelin @ 2008-05-16 10:25 UTC (permalink / raw)
To: André Goddard Rosa; +Cc: Mike Ralphson, Tim Harper, git
[-- Attachment #1: Type: TEXT/PLAIN, Size: 474 bytes --]
Hi,
On Thu, 15 May 2008, André Goddard Rosa wrote:
> >> This patch will make git a little more human friendly, reporting "file.txt: has local changes".
> >
> > Documentation/git-checkout.txt should also change in this case,
> > otherwise users will see different output to that described and
> > possibly get confused if following along with the examples.
> >
>
> I like the idea too.
No comment on the concern that it might break people's scripts? None?
Ciao,
Dscho
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-16 10:25 ` Johannes Schindelin
@ 2008-05-16 11:02 ` Holger Schurig
2008-05-16 11:50 ` Francis Moreau
2008-05-16 12:22 ` Johannes Schindelin
2008-05-16 17:12 ` Kevin Ballard
1 sibling, 2 replies; 24+ messages in thread
From: Holger Schurig @ 2008-05-16 11:02 UTC (permalink / raw)
To: git; +Cc: Johannes Schindelin, André Goddard Rosa, Mike Ralphson,
Tim Harper
> No comment on the concern that it might break people's
> scripts? None?
Scripts should look for exit values :-)
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-16 11:02 ` Holger Schurig
@ 2008-05-16 11:50 ` Francis Moreau
2008-05-16 12:22 ` Johannes Schindelin
1 sibling, 0 replies; 24+ messages in thread
From: Francis Moreau @ 2008-05-16 11:50 UTC (permalink / raw)
To: Holger Schurig
Cc: git, Johannes Schindelin, André Goddard Rosa, Mike Ralphson,
Tim Harper
On Fri, May 16, 2008 at 1:02 PM, Holger Schurig
<hs4233@mail.mn-solutions.de> wrote:
>> No comment on the concern that it might break people's
>> scripts? None?
>
> Scripts should look for exit values :-)
except that they're not documented ;)
--
Francis
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-16 11:02 ` Holger Schurig
2008-05-16 11:50 ` Francis Moreau
@ 2008-05-16 12:22 ` Johannes Schindelin
1 sibling, 0 replies; 24+ messages in thread
From: Johannes Schindelin @ 2008-05-16 12:22 UTC (permalink / raw)
To: Holger Schurig; +Cc: git, André Goddard Rosa, Mike Ralphson, Tim Harper
Hi,
On Fri, 16 May 2008, Holger Schurig wrote:
> > No comment on the concern that it might break people's
> > scripts? None?
>
> Scripts should look for exit values :-)
Clever. And which exit value would you exactly check to see _which_ file
needs an update?
Hth,
Dscho
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-16 10:25 ` Johannes Schindelin
2008-05-16 11:02 ` Holger Schurig
@ 2008-05-16 17:12 ` Kevin Ballard
2008-05-17 3:30 ` André Goddard Rosa
1 sibling, 1 reply; 24+ messages in thread
From: Kevin Ballard @ 2008-05-16 17:12 UTC (permalink / raw)
To: Johannes Schindelin
Cc: André Goddard Rosa, Mike Ralphson, Tim Harper, git
On May 16, 2008, at 6:25 AM, Johannes Schindelin wrote:
> On Thu, 15 May 2008, André Goddard Rosa wrote:
>
>>>> This patch will make git a little more human friendly, reporting
>>>> "file.txt: has local changes".
>>>
>>> Documentation/git-checkout.txt should also change in this case,
>>> otherwise users will see different output to that described and
>>> possibly get confused if following along with the examples.
>>>
>>
>> I like the idea too.
>
> No comment on the concern that it might break people's scripts? None?
How about an ugly hack? Look to see if stdout is a tty, if so spit out
the more human-readable version, otherwise spit out the old version >:-)
-Kevin
--
Kevin Ballard
http://kevin.sb.org
kevin@sb.org
http://www.tildesoft.com
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-16 17:12 ` Kevin Ballard
@ 2008-05-17 3:30 ` André Goddard Rosa
2008-05-17 10:04 ` Johannes Schindelin
0 siblings, 1 reply; 24+ messages in thread
From: André Goddard Rosa @ 2008-05-17 3:30 UTC (permalink / raw)
To: Kevin Ballard; +Cc: Johannes Schindelin, Mike Ralphson, Tim Harper, git
On Fri, May 16, 2008 at 2:12 PM, Kevin Ballard <kevin@sb.org> wrote:
> On May 16, 2008, at 6:25 AM, Johannes Schindelin wrote:
>
>> On Thu, 15 May 2008, André Goddard Rosa wrote:
>>
>>>>> This patch will make git a little more human friendly, reporting
>>>>> "file.txt: has local changes".
>>>>
>>>> Documentation/git-checkout.txt should also change in this case,
>>>> otherwise users will see different output to that described and
>>>> possibly get confused if following along with the examples.
>>>>
>>>
>>> I like the idea too.
>>
>> No comment on the concern that it might break people's scripts? None?
>
>
> How about an ugly hack? Look to see if stdout is a tty, if so spit out the
> more human-readable version, otherwise spit out the old version >:-)
Is this user interface set on stone? I think we should reserve the
right to improve always.
I would deprecate the current message, but I think that most users
cannot find so much of a sense in the former message,
although the script developer can easily change his scripts to search
for ´cannot merge´ instead.
Do you have a better idea?
---
[PATCH] "not uptodate" changed to "has local changes"
Use more straightforward message for regular user.
Signed-off-by: Andre Goddard Rosa <andre.goddard@gmail.com>
diff --git a/Documentation/git-checkout.txt b/Documentation/git-checkout.txt
index a644173..624dea6 100644
--- a/Documentation/git-checkout.txt
+++ b/Documentation/git-checkout.txt
@@ -168,7 +168,7 @@ the above checkout would fail like this:
+
------------
$ git checkout mytopic
-fatal: Entry 'frotz' not uptodate. Cannot merge.
+fatal: Entry 'frotz' not uptodate, it has local changes. Cannot merge.
------------
+
You can give the `-m` flag to the command, which would try a
^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 3:30 ` André Goddard Rosa
@ 2008-05-17 10:04 ` Johannes Schindelin
2008-05-17 14:44 ` Steven Walter
2008-05-17 15:08 ` Wincent Colaiuta
0 siblings, 2 replies; 24+ messages in thread
From: Johannes Schindelin @ 2008-05-17 10:04 UTC (permalink / raw)
To: André Goddard Rosa; +Cc: Kevin Ballard, Mike Ralphson, Tim Harper, git
[-- Attachment #1: Type: TEXT/PLAIN, Size: 1302 bytes --]
Hi,
On Sat, 17 May 2008, André Goddard Rosa wrote:
> On Fri, May 16, 2008 at 2:12 PM, Kevin Ballard <kevin@sb.org> wrote:
> > On May 16, 2008, at 6:25 AM, Johannes Schindelin wrote:
> >
> >> On Thu, 15 May 2008, André Goddard Rosa wrote:
> >>
> >>>>> This patch will make git a little more human friendly, reporting
> >>>>> "file.txt: has local changes".
> >>>>
> >>>> Documentation/git-checkout.txt should also change in this case,
> >>>> otherwise users will see different output to that described and
> >>>> possibly get confused if following along with the examples.
> >>>>
> >>>
> >>> I like the idea too.
> >>
> >> No comment on the concern that it might break people's scripts? None?
> >
> >
> > How about an ugly hack? Look to see if stdout is a tty, if so spit out the
> > more human-readable version, otherwise spit out the old version >:-)
>
> Is this user interface set on stone? I think we should reserve the right
> to improve always.
Umm.
As has been mentioned, this is not a "user interface". The message you
are seeing comes from a _plumbing_ program, i.e. something _not_ meant for
human consumption.
I still think that it might be better to add a command line option with a
custom message, because that would _not_ break backwards-compatibility.
Thankyouverymuch,
Dscho
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 10:04 ` Johannes Schindelin
@ 2008-05-17 14:44 ` Steven Walter
2008-05-17 16:12 ` Sverre Rabbelier
2008-05-17 15:08 ` Wincent Colaiuta
1 sibling, 1 reply; 24+ messages in thread
From: Steven Walter @ 2008-05-17 14:44 UTC (permalink / raw)
To: Johannes Schindelin
Cc: André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
On Sat, May 17, 2008 at 6:04 AM, Johannes Schindelin
<Johannes.Schindelin@gmx.de> wrote:
>> Is this user interface set on stone? I think we should reserve the right
>> to improve always.
>
> Umm.
>
> As has been mentioned, this is not a "user interface". The message you
> are seeing comes from a _plumbing_ program, i.e. something _not_ meant for
> human consumption.
>
> I still think that it might be better to add a command line option with a
> custom message, because that would _not_ break backwards-compatibility.
With this dedication to backwards-compatibility, we'll be at Windows
Vista quality in no time.
--
-Steven Walter <stevenrwalter@gmail.com>
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 10:04 ` Johannes Schindelin
2008-05-17 14:44 ` Steven Walter
@ 2008-05-17 15:08 ` Wincent Colaiuta
2008-05-17 15:32 ` Matthieu Moy
1 sibling, 1 reply; 24+ messages in thread
From: Wincent Colaiuta @ 2008-05-17 15:08 UTC (permalink / raw)
To: Johannes Schindelin
Cc: André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
El 17/5/2008, a las 12:04, Johannes Schindelin escribió:
> Hi,
>
> On Sat, 17 May 2008, André Goddard Rosa wrote:
>
>> Is this user interface set on stone? I think we should reserve the
>> right
>> to improve always.
>
> Umm.
>
> As has been mentioned, this is not a "user interface". The message
> you
> are seeing comes from a _plumbing_ program, i.e. something _not_
> meant for
> human consumption.
That would indicate a problem, if stuff not intended for human
consumption is being dished up for exactly that: human consumption.
> I still think that it might be better to add a command line option
> with a
> custom message, because that would _not_ break backwards-
> compatibility.
Sounds like clutter to me. I'd instead favor just holding back this
patch until 1.6, when (minor) "compatibility breaking" changes would
be acceptable.
Wincent
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 15:08 ` Wincent Colaiuta
@ 2008-05-17 15:32 ` Matthieu Moy
0 siblings, 0 replies; 24+ messages in thread
From: Matthieu Moy @ 2008-05-17 15:32 UTC (permalink / raw)
To: Wincent Colaiuta
Cc: Johannes Schindelin, André Goddard Rosa, Kevin Ballard,
Mike Ralphson, Tim Harper, git
Wincent Colaiuta <win@wincent.com> writes:
> That would indicate a problem, if stuff not intended for human
> consumption is being dished up for exactly that: human consumption.
There have been other instances of this one, and the output of
git-update-index has been replaced by a call to "git status" in the
porcelain.
--
Matthieu
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 14:44 ` Steven Walter
@ 2008-05-17 16:12 ` Sverre Rabbelier
2008-05-17 18:44 ` Johannes Schindelin
2008-05-17 19:03 ` Re* " Junio C Hamano
0 siblings, 2 replies; 24+ messages in thread
From: Sverre Rabbelier @ 2008-05-17 16:12 UTC (permalink / raw)
To: Steven Walter
Cc: Johannes Schindelin, André Goddard Rosa, Kevin Ballard,
Mike Ralphson, Tim Harper, git
On Sat, May 17, 2008 at 4:44 PM, Steven Walter <stevenrwalter@gmail.com> wrote:
> With this dedication to backwards-compatibility, we'll be at Windows
> Vista quality in no time.
I very much agree here, given the nature of scripts (that is, being
very easy to update), I think we should try not to be too strict in
backwards-compatibility or we'll lose the flexibility that is very
much needed when developing a Good Product (tm) As long as such
compatibility breaking changes are marked (in BIG LETTERS) in the
changelog/release notes I think that would be a 'sacrifice' we should
consider making.
--
Cheers,
Sverre Rabbelier
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 16:12 ` Sverre Rabbelier
@ 2008-05-17 18:44 ` Johannes Schindelin
2008-05-17 20:14 ` Sverre Rabbelier
2008-05-17 19:03 ` Re* " Junio C Hamano
1 sibling, 1 reply; 24+ messages in thread
From: Johannes Schindelin @ 2008-05-17 18:44 UTC (permalink / raw)
To: Sverre Rabbelier
Cc: Steven Walter, André Goddard Rosa, Kevin Ballard,
Mike Ralphson, Tim Harper, git
Hi,
On Sat, 17 May 2008, Sverre Rabbelier wrote:
> On Sat, May 17, 2008 at 4:44 PM, Steven Walter <stevenrwalter@gmail.com>
> wrote:
>
> > With this dedication to backwards-compatibility, we'll be at Windows
> > Vista quality in no time.
That is silly at best, especially given that Vista is _not_
backwards-compatible. Not to mention that it is not forkable, because it
is not Open Source.
> I very much agree here, given the nature of scripts (that is, being very
> easy to update), I think we should try not to be too strict in
> backwards-compatibility or we'll lose the flexibility that is very much
> needed when developing a Good Product (tm) As long as such compatibility
> breaking changes are marked (in BIG LETTERS) in the changelog/release
> notes I think that would be a 'sacrifice' we should consider making.
Had you (one of our GSoc students) not replied, I would not even have
bothered to say anything.
But I strongly disagree with the notion that it is okay to fsck with
old-timers (who would be harmed by breaking backwards-incompatibility,
and nobody else), especially given that it is mostly old-timers who turned
Git into the Good Product(tm) it is.
Ciao,
Dscho
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re* [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 16:12 ` Sverre Rabbelier
2008-05-17 18:44 ` Johannes Schindelin
@ 2008-05-17 19:03 ` Junio C Hamano
2008-05-17 20:29 ` Sverre Rabbelier
2008-05-19 6:55 ` Wincent Colaiuta
1 sibling, 2 replies; 24+ messages in thread
From: Junio C Hamano @ 2008-05-17 19:03 UTC (permalink / raw)
To: sverre
Cc: Steven Walter, Johannes Schindelin, André Goddard Rosa,
Kevin Ballard, Mike Ralphson, Tim Harper, git
"Sverre Rabbelier" <alturin@gmail.com> writes:
> On Sat, May 17, 2008 at 4:44 PM, Steven Walter <stevenrwalter@gmail.com> wrote:
>> With this dedication to backwards-compatibility, we'll be at Windows
>> Vista quality in no time.
>
> I very much agree here, given the nature of scripts (that is, being
> very easy to update), I think we should try not to be too strict in
> backwards-compatibility or we'll lose the flexibility that is very
> much needed when developing a Good Product (tm) As long as such
> compatibility breaking changes are marked (in BIG LETTERS) in the
> changelog/release notes I think that would be a 'sacrifice' we should
> consider making.
Don't feed the troll by responding to a cheap shot.
The plumbing output is sacred as it is an API. We _could_ change it if it
is broken in such a way that it cannot convey necessary information fully,
but we just do not _reword_ for the sake of rewording. If somebody does
not like it, s/he is complaining too late. S/he should have been here in
early May 2005 and make the language used by the API closer to what humans
read. S/he wasn't here. Too bad, and it is too late.
And people who complain should look at a bigger picture. Look at what was
suggested by one of them and think for five seconds:
$ git checkout mytopic
-fatal: Entry 'frotz' not uptodate. Cannot merge.
+fatal: Entry 'frotz' has local changes. Cannot merge.
If you do not see something wrong with this output, your brain has already
been rotten with use of git for too long a time. Nobody asked us to
"merge" but why are we talking about "Cannot merge"?
Try a different approach along this patch instead.
$ git-checkout pu
error: You have local changes to 'Makefile'; cannot switch branches.
There are other places that ask unpack_trees() to n-way merge, detect
issues _and_ let it issue error message on its own, which people who
complained in this thread can identify and improve, but I did this as a
demonstration and replaced only one message.
Yes I know about C99 structure initializers. I'd love to use them but we
try to be nice to compilers without it.
builtin-checkout.c | 2 ++
unpack-trees.c | 47 +++++++++++++++++++++++++++++++++--------------
unpack-trees.h | 9 +++++++++
3 files changed, 44 insertions(+), 14 deletions(-)
diff --git a/builtin-checkout.c b/builtin-checkout.c
index 10ec137..83da7ca 100644
--- a/builtin-checkout.c
+++ b/builtin-checkout.c
@@ -236,6 +236,8 @@ static int merge_working_tree(struct checkout_opts *opts,
topts.src_index = &the_index;
topts.dst_index = &the_index;
+ topts.msgs.not_uptodate_file = "You have local changes to '%s'; cannot switch branches.";
+
refresh_cache(REFRESH_QUIET);
if (unmerged_cache()) {
diff --git a/unpack-trees.c b/unpack-trees.c
index 1ab28fd..bec12dc 100644
--- a/unpack-trees.c
+++ b/unpack-trees.c
@@ -8,6 +8,28 @@
#include "progress.h"
#include "refs.h"
+static struct unpack_trees_error_msgs unpack_default_errors = {
+ /* would_overwrite */
+ "Entry '%s' would be overwritten by merge. Cannot merge.",
+
+ /* not_uptodate_file */
+ "Entry '%s' not uptodate. Cannot merge.",
+
+ /* not_uptodate_dir */
+ "Updating '%s' would lose untracked files in it",
+
+ /* would_lose_untracked */
+ "Untracked working tree file '%s' would be %s by merge.",
+
+ /* bind_overlap */
+ "Entry '%s' overlaps with '%s'. Cannot bind.",
+};
+
+#define ERRORMSG(o,fld) \
+ ( ((o) && (o)->msgs.fld) \
+ ? ((o)->msgs.fld) \
+ : (unpack_default_errors.fld) )
+
static void add_entry(struct unpack_trees_options *o, struct cache_entry *ce,
unsigned int set, unsigned int clear)
{
@@ -383,10 +405,9 @@ int unpack_trees(unsigned len, struct tree_desc *t, struct unpack_trees_options
/* Here come the merge functions */
-static int reject_merge(struct cache_entry *ce)
+static int reject_merge(struct cache_entry *ce, struct unpack_trees_options *o)
{
- return error("Entry '%s' would be overwritten by merge. Cannot merge.",
- ce->name);
+ return error(ERRORMSG(o, would_overwrite), ce->name);
}
static int same(struct cache_entry *a, struct cache_entry *b)
@@ -430,7 +451,7 @@ static int verify_uptodate(struct cache_entry *ce,
if (errno == ENOENT)
return 0;
return o->gently ? -1 :
- error("Entry '%s' not uptodate. Cannot merge.", ce->name);
+ error(ERRORMSG(o, not_uptodate_file), ce->name);
}
static void invalidate_ce_path(struct cache_entry *ce, struct unpack_trees_options *o)
@@ -517,8 +538,7 @@ static int verify_clean_subdirectory(struct cache_entry *ce, const char *action,
i = read_directory(&d, ce->name, pathbuf, namelen+1, NULL);
if (i)
return o->gently ? -1 :
- error("Updating '%s' would lose untracked files in it",
- ce->name);
+ error(ERRORMSG(o, not_uptodate_dir), ce->name);
free(pathbuf);
return cnt;
}
@@ -618,8 +638,7 @@ static int verify_absent(struct cache_entry *ce, const char *action,
}
return o->gently ? -1 :
- error("Untracked working tree file '%s' "
- "would be %s by merge.", ce->name, action);
+ error(ERRORMSG(o, would_lose_untracked), ce->name, action);
}
return 0;
}
@@ -751,7 +770,7 @@ int threeway_merge(struct cache_entry **stages, struct unpack_trees_options *o)
/* #14, #14ALT, #2ALT */
if (remote && !df_conflict_head && head_match && !remote_match) {
if (index && !same(index, remote) && !same(index, head))
- return o->gently ? -1 : reject_merge(index);
+ return o->gently ? -1 : reject_merge(index, o);
return merged_entry(remote, index, o);
}
/*
@@ -759,7 +778,7 @@ int threeway_merge(struct cache_entry **stages, struct unpack_trees_options *o)
* make sure that it matches head.
*/
if (index && !same(index, head))
- return o->gently ? -1 : reject_merge(index);
+ return o->gently ? -1 : reject_merge(index, o);
if (head) {
/* #5ALT, #15 */
@@ -901,11 +920,11 @@ int twoway_merge(struct cache_entry **src, struct unpack_trees_options *o)
else {
/* all other failures */
if (oldtree)
- return o->gently ? -1 : reject_merge(oldtree);
+ return o->gently ? -1 : reject_merge(oldtree, o);
if (current)
- return o->gently ? -1 : reject_merge(current);
+ return o->gently ? -1 : reject_merge(current, o);
if (newtree)
- return o->gently ? -1 : reject_merge(newtree);
+ return o->gently ? -1 : reject_merge(newtree, o);
return -1;
}
}
@@ -931,7 +950,7 @@ int bind_merge(struct cache_entry **src,
o->merge_size);
if (a && old)
return o->gently ? -1 :
- error("Entry '%s' overlaps with '%s'. Cannot bind.", a->name, old->name);
+ error(ERRORMSG(o, bind_overlap), a->name, old->name);
if (!a)
return keep_entry(old, o);
else
diff --git a/unpack-trees.h b/unpack-trees.h
index d436d6c..94e5672 100644
--- a/unpack-trees.h
+++ b/unpack-trees.h
@@ -8,6 +8,14 @@ struct unpack_trees_options;
typedef int (*merge_fn_t)(struct cache_entry **src,
struct unpack_trees_options *options);
+struct unpack_trees_error_msgs {
+ const char *would_overwrite;
+ const char *not_uptodate_file;
+ const char *not_uptodate_dir;
+ const char *would_lose_untracked;
+ const char *bind_overlap;
+};
+
struct unpack_trees_options {
unsigned int reset:1,
merge:1,
@@ -23,6 +31,7 @@ struct unpack_trees_options {
int pos;
struct dir_struct *dir;
merge_fn_t fn;
+ struct unpack_trees_error_msgs msgs;
int head_idx;
int merge_size;
^ permalink raw reply related [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 18:44 ` Johannes Schindelin
@ 2008-05-17 20:14 ` Sverre Rabbelier
[not found] ` <200805181032.m4IAWjE0012832@mi0.bluebottle.com>
0 siblings, 1 reply; 24+ messages in thread
From: Sverre Rabbelier @ 2008-05-17 20:14 UTC (permalink / raw)
To: Johannes Schindelin
Cc: Steven Walter, André Goddard Rosa, Kevin Ballard,
Mike Ralphson, Tim Harper, git
On Sat, May 17, 2008 at 8:44 PM, Johannes Schindelin > But I strongly
disagree with the notion that it is okay to fsck with
> old-timers (who would be harmed by breaking backwards-incompatibility,
> and nobody else), especially given that it is mostly old-timers who turned
> Git into the Good Product(tm) it is.
But those old-timers can be updated can't they? Also, shouldn't we
have tests to see if they 'break' because of changes?
--
Cheers,
Sverre Rabbelier
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 19:03 ` Re* " Junio C Hamano
@ 2008-05-17 20:29 ` Sverre Rabbelier
2008-05-19 6:55 ` Wincent Colaiuta
1 sibling, 0 replies; 24+ messages in thread
From: Sverre Rabbelier @ 2008-05-17 20:29 UTC (permalink / raw)
To: Junio C Hamano
Cc: Steven Walter, Johannes Schindelin, André Goddard Rosa,
Kevin Ballard, Mike Ralphson, Tim Harper, git
On Sat, May 17, 2008 at 9:03 PM, Junio C Hamano <gitster@pobox.com> wrote:
> Don't feed the troll by responding to a cheap shot.
Yes, a cheap shot, but I think one trying to make a point.
> The plumbing output is sacred as it is an API. We _could_ change it if it
> is broken in such a way that it cannot convey necessary information fully,
> but we just do not _reword_ for the sake of rewording. If somebody does
> not like it, s/he is complaining too late. S/he should have been here in
> early May 2005 and make the language used by the API closer to what humans
> read. S/he wasn't here. Too bad, and it is too late.
Mhh.. I guess I didn't realize how strongly git still is "many
commands that are good at what they do" that together form a coherent
entity.
> If you do not see something wrong with this output, your brain has already
> been rotten with use of git for too long a time. Nobody asked us to
> "merge" but why are we talking about "Cannot merge"?
Very good point, perhaps we should consider double-checking them all
and improving them for one of the next 1.x releases.
> Try a different approach along this patch instead.
>
> $ git-checkout pu
> error: You have local changes to 'Makefile'; cannot switch branches.
>
> There are other places that ask unpack_trees() to n-way merge, detect
> issues _and_ let it issue error message on its own, which people who
> complained in this thread can identify and improve, but I did this as a
> demonstration and replaced only one message.
The patch looks like a step in the right direction, but if there is
interest in improving the error messaging system why not do it right
and make it generic. Instead of each file reinventing the wheel create
a more generic system that uses a configuration file (I think this was
suggested earlier). If we choose something like that, perhaps it would
be nice to add a 'scripting' mode, which provides with a CLI-like
messages instead of the usual human-readable ones (and thus less easy
to parse).
<snip patch>
--
Cheers,
Sverre Rabbelier
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: [PATCH] "not uptodate" changed to "has local changes"
[not found] ` <200805181032.m4IAWjE0012832@mi0.bluebottle.com>
@ 2008-05-18 11:11 ` Sverre Rabbelier
0 siblings, 0 replies; 24+ messages in thread
From: Sverre Rabbelier @ 2008-05-18 11:11 UTC (permalink / raw)
To: しらいしななこ
Cc: Junio C Hamano, Johannes Schindelin, Steven Walter,
André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
On Sun, May 18, 2008 at 12:31 PM, しらいしななこ <nanako3@bluebottle.com> wrote:
> What advantage are you bringing to the table for them to be worth bothering to update, other than "if they update then they can get their scripts working again after you break them by rewording messages for no good reason"? Why do you punish the old-timers for using the well established API?
My reason was that (perhaps not as much in this case, but I meant to
speak in general) the message is confusing/not clear enough.
> Did you study Junio's patch before you responded to his message? The point of the suggestion was that he reworded the message given by git-checkout that is a porcelain command without breaking output from read-tree that is a plumbing command. In other words, you can improve output from porcelain commands without making unnecessary changes to plumbing.
I hadn't read his e-mail when I was replying, my Internet has been
playing up lately (same for about half of the Netherlands due to a
problem at one of our biggest ISPs). I did reply to it though:
http://thread.gmane.org/gmane.comp.version-control.git/81100
--
Cheers,
Sverre Rabbelier
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH] "not uptodate" changed to "has local changes"
2008-05-17 19:03 ` Re* " Junio C Hamano
2008-05-17 20:29 ` Sverre Rabbelier
@ 2008-05-19 6:55 ` Wincent Colaiuta
2008-05-19 17:47 ` Junio C Hamano
1 sibling, 1 reply; 24+ messages in thread
From: Wincent Colaiuta @ 2008-05-19 6:55 UTC (permalink / raw)
To: Junio C Hamano
Cc: sverre, Steven Walter, Johannes Schindelin,
André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
El 17/5/2008, a las 21:03, Junio C Hamano escribió:
> + /* not_uptodate_file */
> + "Entry '%s' not uptodate. Cannot merge.",
Minor nit, "uptodate" is not a word. Should be either "up-to-date" or
"up to date"; most dictionaries list both.
Cheers,
Wincent
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH] "not uptodate" changed to "has local changes"
2008-05-19 6:55 ` Wincent Colaiuta
@ 2008-05-19 17:47 ` Junio C Hamano
2008-05-19 18:28 ` Sverre Rabbelier
2008-05-19 19:32 ` Daniel Barkalow
0 siblings, 2 replies; 24+ messages in thread
From: Junio C Hamano @ 2008-05-19 17:47 UTC (permalink / raw)
To: Wincent Colaiuta
Cc: sverre, Steven Walter, Johannes Schindelin,
André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
Wincent Colaiuta <win@wincent.com> writes:
> El 17/5/2008, a las 21:03, Junio C Hamano escribió:
>> + /* not_uptodate_file */
>> + "Entry '%s' not uptodate. Cannot merge.",
>
>
> Minor nit, "uptodate" is not a word. Should be either "up-to-date" or
> "up to date"; most dictionaries list both.
Why does *everybody* keep missing the whole point of this patch?
Grumble.
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH] "not uptodate" changed to "has local changes"
2008-05-19 17:47 ` Junio C Hamano
@ 2008-05-19 18:28 ` Sverre Rabbelier
2008-05-19 19:32 ` Daniel Barkalow
1 sibling, 0 replies; 24+ messages in thread
From: Sverre Rabbelier @ 2008-05-19 18:28 UTC (permalink / raw)
To: Junio C Hamano
Cc: Wincent Colaiuta, Steven Walter, Johannes Schindelin,
André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
On Mon, May 19, 2008 at 7:47 PM, Junio C Hamano <gitster@pobox.com> wrote:
> Why does *everybody* keep missing the whole point of this patch?
Isn't it to make it possible to change the error messages at porcelain
level while allowing the plumbing to remain backward compatibility?
--
Cheers,
Sverre Rabbelier
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH] "not uptodate" changed to "has local changes"
2008-05-19 17:47 ` Junio C Hamano
2008-05-19 18:28 ` Sverre Rabbelier
@ 2008-05-19 19:32 ` Daniel Barkalow
2008-05-21 7:07 ` Junio C Hamano
1 sibling, 1 reply; 24+ messages in thread
From: Daniel Barkalow @ 2008-05-19 19:32 UTC (permalink / raw)
To: Junio C Hamano
Cc: Wincent Colaiuta, sverre, Steven Walter, Johannes Schindelin,
André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
[-- Attachment #1: Type: TEXT/PLAIN, Size: 893 bytes --]
On Mon, 19 May 2008, Junio C Hamano wrote:
> Wincent Colaiuta <win@wincent.com> writes:
>
> > El 17/5/2008, a las 21:03, Junio C Hamano escribió:
> >> + /* not_uptodate_file */
> >> + "Entry '%s' not uptodate. Cannot merge.",
> >
> >
> > Minor nit, "uptodate" is not a word. Should be either "up-to-date" or
> > "up to date"; most dictionaries list both.
>
> Why does *everybody* keep missing the whole point of this patch?
That section needs a comment stating that it's the scripting API, not just
an arbitrary set of messages. For that matter, maybe those shouldn't be
the default set, but an alternate set used (as a group) by plumbing
programs; I don't think it's too likely that there will be a whole lot of
new plumbing programs, and new porcelain programs that don't specify
anything probably ought to get something more generic.
-Daniel
*This .sig left intentionally blank*
^ permalink raw reply [flat|nested] 24+ messages in thread
* Re: Re* [PATCH] "not uptodate" changed to "has local changes"
2008-05-19 19:32 ` Daniel Barkalow
@ 2008-05-21 7:07 ` Junio C Hamano
0 siblings, 0 replies; 24+ messages in thread
From: Junio C Hamano @ 2008-05-21 7:07 UTC (permalink / raw)
To: Daniel Barkalow
Cc: Wincent Colaiuta, sverre, Steven Walter, Johannes Schindelin,
André Goddard Rosa, Kevin Ballard, Mike Ralphson, Tim Harper,
git
Daniel Barkalow <barkalow@iabervon.org> writes:
> On Mon, 19 May 2008, Junio C Hamano wrote:
>
>> Why does *everybody* keep missing the whole point of this patch?
>
> That section needs a comment stating that it's the scripting API, not just
> an arbitrary set of messages.
Yeah, that is a very good explanation. Thanks for a constructive
suggestion for improvements.
Here is an incremental on top of the one I sent out, in case people want
to improve on it.
unpack-trees.c | 12 ++++++++++--
1 files changed, 10 insertions(+), 2 deletions(-)
diff --git a/unpack-trees.c b/unpack-trees.c
index da3bdc8..0de5a31 100644
--- a/unpack-trees.c
+++ b/unpack-trees.c
@@ -8,7 +8,15 @@
#include "progress.h"
#include "refs.h"
-static struct unpack_trees_error_msgs unpack_default_errors = {
+/*
+ * Error messages expected by scripts out of plumbing commands such as
+ * read-tree. Non-scripted Porcelain is not required to use these messages
+ * and in fact are encouraged to reword them to better suit their particular
+ * situation better. See how "git checkout" replaces not_uptodate_file to
+ * explain why it does not allow switching between branches when you have
+ * local changes, for example.
+ */
+static struct unpack_trees_error_msgs unpack_plumbing_errors = {
/* would_overwrite */
"Entry '%s' would be overwritten by merge. Cannot merge.",
@@ -28,7 +36,7 @@ static struct unpack_trees_error_msgs unpack_default_errors = {
#define ERRORMSG(o,fld) \
( ((o) && (o)->msgs.fld) \
? ((o)->msgs.fld) \
- : (unpack_default_errors.fld) )
+ : (unpack_plumbing_errors.fld) )
static void add_entry(struct unpack_trees_options *o, struct cache_entry *ce,
unsigned int set, unsigned int clear)
^ permalink raw reply related [flat|nested] 24+ messages in thread
end of thread, other threads:[~2008-05-21 7:08 UTC | newest]
Thread overview: 24+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-05-03 16:59 [PATCH] "not uptodate" changed to "has local changes" Tim Harper
2008-05-06 13:31 ` Mike Ralphson
2008-05-16 2:14 ` André Goddard Rosa
2008-05-16 10:25 ` Johannes Schindelin
2008-05-16 11:02 ` Holger Schurig
2008-05-16 11:50 ` Francis Moreau
2008-05-16 12:22 ` Johannes Schindelin
2008-05-16 17:12 ` Kevin Ballard
2008-05-17 3:30 ` André Goddard Rosa
2008-05-17 10:04 ` Johannes Schindelin
2008-05-17 14:44 ` Steven Walter
2008-05-17 16:12 ` Sverre Rabbelier
2008-05-17 18:44 ` Johannes Schindelin
2008-05-17 20:14 ` Sverre Rabbelier
[not found] ` <200805181032.m4IAWjE0012832@mi0.bluebottle.com>
2008-05-18 11:11 ` Sverre Rabbelier
2008-05-17 19:03 ` Re* " Junio C Hamano
2008-05-17 20:29 ` Sverre Rabbelier
2008-05-19 6:55 ` Wincent Colaiuta
2008-05-19 17:47 ` Junio C Hamano
2008-05-19 18:28 ` Sverre Rabbelier
2008-05-19 19:32 ` Daniel Barkalow
2008-05-21 7:07 ` Junio C Hamano
2008-05-17 15:08 ` Wincent Colaiuta
2008-05-17 15:32 ` Matthieu Moy
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).