git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] git wrapper: also uses aliases to suggest mistyped commands
@ 2008-09-10 15:54 Pieter de Bie
  2008-09-10 21:44 ` Junio C Hamano
  0 siblings, 1 reply; 3+ messages in thread
From: Pieter de Bie @ 2008-09-10 15:54 UTC (permalink / raw)
  To: Git Mailinglist, Junio C Hamano; +Cc: Pieter de Bie


Signed-off-by: Pieter de Bie <pdebie@ai.rug.nl>
---
 help.c |   15 +++++++++++++++
 1 files changed, 15 insertions(+), 0 deletions(-)

diff --git a/help.c b/help.c
index 300cd38..24904d4 100644
--- a/help.c
+++ b/help.c
@@ -262,11 +262,15 @@ int is_in_cmdlist(struct cmdnames *c, const char *s)
 }
 
 static int autocorrect;
+static struct cmdnames aliases;
 
 static int git_unknown_cmd_config(const char *var, const char *value, void *cb)
 {
 	if (!strcmp(var, "help.autocorrect"))
 		autocorrect = git_config_int(var,value);
+	/* Also use aliases for command lookup */
+	if (!prefixcmp(var, "alias."))
+		add_cmdname(&aliases, var + 6, strlen(var + 6));
 
 	return git_default_config(var, value, cb);
 }
@@ -280,6 +284,15 @@ static int levenshtein_compare(const void *p1, const void *p2)
 	return l1 != l2 ? l1 - l2 : strcmp(s1, s2);
 }
 
+static void add_cmd_list(struct cmdnames *cmds, struct cmdnames *old)
+{
+	int i;
+	ALLOC_GROW(cmds->names, cmds->cnt + old->cnt, cmds->alloc);
+
+	for (i = 0; i < old->cnt; i++)
+		cmds->names[cmds->cnt++] = old->names[i];
+}
+
 const char *help_unknown_cmd(const char *cmd)
 {
 	int i, n, best_similarity = 0;
@@ -287,11 +300,13 @@ const char *help_unknown_cmd(const char *cmd)
 
 	memset(&main_cmds, 0, sizeof(main_cmds));
 	memset(&other_cmds, 0, sizeof(main_cmds));
+	memset(&aliases, 0, sizeof(aliases));
 
 	git_config(git_unknown_cmd_config, NULL);
 
 	load_command_list("git-", &main_cmds, &other_cmds);
 
+	add_cmd_list(&main_cmds, &aliases);
 	ALLOC_GROW(main_cmds.names, main_cmds.cnt + other_cmds.cnt,
 		   main_cmds.alloc);
 	memcpy(main_cmds.names + main_cmds.cnt, other_cmds.names,
-- 
1.6.0.1.346.g880d9.dirty

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH] git wrapper: also uses aliases to suggest mistyped commands
  2008-09-10 15:54 [PATCH] git wrapper: also uses aliases to suggest mistyped commands Pieter de Bie
@ 2008-09-10 21:44 ` Junio C Hamano
  2008-09-11 10:37   ` Pieter de Bie
  0 siblings, 1 reply; 3+ messages in thread
From: Junio C Hamano @ 2008-09-10 21:44 UTC (permalink / raw)
  To: Pieter de Bie; +Cc: Git Mailinglist

Pieter de Bie <pdebie@ai.rug.nl> writes:

> @@ -280,6 +284,15 @@ static int levenshtein_compare(const void *p1, const void *p2)
>  	return l1 != l2 ? l1 - l2 : strcmp(s1, s2);
>  }
>  
> +static void add_cmd_list(struct cmdnames *cmds, struct cmdnames *old)
> +{
> +	int i;
> +	ALLOC_GROW(cmds->names, cmds->cnt + old->cnt, cmds->alloc);
> +
> +	for (i = 0; i < old->cnt; i++)
> +		cmds->names[cmds->cnt++] = old->names[i];
> +}
> +
>  const char *help_unknown_cmd(const char *cmd)
>  {
>  	int i, n, best_similarity = 0;
> @@ -287,11 +300,13 @@ const char *help_unknown_cmd(const char *cmd)
>  
>  	memset(&main_cmds, 0, sizeof(main_cmds));
>  	memset(&other_cmds, 0, sizeof(main_cmds));
> +	memset(&aliases, 0, sizeof(aliases));
>  
>  	git_config(git_unknown_cmd_config, NULL);
>  
>  	load_command_list("git-", &main_cmds, &other_cmds);
>  
> +	add_cmd_list(&main_cmds, &aliases);
>  	ALLOC_GROW(main_cmds.names, main_cmds.cnt + other_cmds.cnt,
>  		   main_cmds.alloc);
>  	memcpy(main_cmds.names + main_cmds.cnt, other_cmds.names,

I think your add_cmd_list() to smash two lists into one is a good
abstraction to use here, but the existing code that can be seen at the
tail end of the context already does that between main and other command
list in a slightly different way.

Aliases should not hide the commands available elsewhere, and the actual
execution codepath around ll.480-490 in git.c avoids getting fooled by
misconfigured aliases, but you do not protect yourself from that kind of
misconfiguration in this patch.  You can have both "git-foo" command on
your private $PATH and alias.foo in your configuration, and they will have
the same levenshtein score.  I suspect this will cause the same "foo"
suggested twice when the user types "git fo" from the command line.

Here is a suggested fix-up on top of your patch to address these issues.

---
 help.c |   13 +++++++------
 1 files changed, 7 insertions(+), 6 deletions(-)

diff --git i/help.c w/help.c
index 595342f..fd87bb5 100644
--- i/help.c
+++ w/help.c
@@ -291,6 +291,9 @@ static void add_cmd_list(struct cmdnames *cmds, struct cmdnames *old)
 
 	for (i = 0; i < old->cnt; i++)
 		cmds->names[cmds->cnt++] = old->names[i];
+	free(old->names);
+	old->cnt = 0;
+	old->names = NULL;
 }
 
 const char *help_unknown_cmd(const char *cmd)
@@ -307,12 +310,10 @@ const char *help_unknown_cmd(const char *cmd)
 	load_command_list("git-", &main_cmds, &other_cmds);
 
 	add_cmd_list(&main_cmds, &aliases);
-	ALLOC_GROW(main_cmds.names, main_cmds.cnt + other_cmds.cnt,
-		   main_cmds.alloc);
-	memcpy(main_cmds.names + main_cmds.cnt, other_cmds.names,
-	       other_cmds.cnt * sizeof(other_cmds.names[0]));
-	main_cmds.cnt += other_cmds.cnt;
-	free(other_cmds.names);
+	add_cmd_list(&main_cmds, &other_cmds);
+	qsort(main_cmds.names, main_cmds.cnt,
+	      sizeof(main_cmds.names), cmdname_compare);
+	uniq(&main_cmds);
 
 	/* This reuses cmdname->len for similarity index */
 	for (i = 0; i < main_cmds.cnt; ++i)

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH] git wrapper: also uses aliases to suggest mistyped commands
  2008-09-10 21:44 ` Junio C Hamano
@ 2008-09-11 10:37   ` Pieter de Bie
  0 siblings, 0 replies; 3+ messages in thread
From: Pieter de Bie @ 2008-09-11 10:37 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: Git Mailinglist


On 10 sep 2008, at 23:44, Junio C Hamano wrote:

> Aliases should not hide the commands available elsewhere, and the  
> actual
> execution codepath around ll.480-490 in git.c avoids getting fooled by
> misconfigured aliases, but you do not protect yourself from that  
> kind of
> misconfiguration in this patch.  You can have both "git-foo" command  
> on
> your private $PATH and alias.foo in your configuration, and they  
> will have
> the same levenshtein score.  I suspect this will cause the same "foo"
> suggested twice when the user types "git fo" from the command line.

Yes, I didn't think of that.

> Here is a suggested fix-up on top of your patch to address these  
> issues.

Looks good. Do you want me to resend the patch or will you squash it?

- Pieter

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2008-09-11 10:38 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-09-10 15:54 [PATCH] git wrapper: also uses aliases to suggest mistyped commands Pieter de Bie
2008-09-10 21:44 ` Junio C Hamano
2008-09-11 10:37   ` Pieter de Bie

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).