This is a patch for my work on one of the micro projects, as I intend
to apply for the Google Summer of Code 2015 under the Git community.
This patch gives the user the oppotunity to specify configuration
options for some commonly used command-line options for exampel:
        git config defopt.am 'am -3'
---
 Makefile |    1 +
 defopt.c |   24 ++++++++++++++++++++++++
 git.c    |   56 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 81 insertions(+)
 create mode 100644 defopt.c

diff --git a/Makefile b/Makefile
index 2320de5..e713e23 100644
--- a/Makefile
+++ b/Makefile
@@ -789,6 +789,7 @@ LIB_OBJS += csum-file.o
 LIB_OBJS += ctype.o
 LIB_OBJS += date.o
 LIB_OBJS += decorate.o
+LIB_OBJS += defopt.o
 LIB_OBJS += diffcore-break.o
 LIB_OBJS += diffcore-delta.o
 LIB_OBJS += diffcore-order.o
diff --git a/defopt.c b/defopt.c
new file mode 100644
index 0000000..b4fa9e2
--- /dev/null
+++ b/defopt.c
@@ -0,0 +1,24 @@
+#include "cache.h"
+
+static const char *defopt_key;
+static char *defopt_val;
+
+static int defopt_lookup_cb(const char *k, const char *v, void *cb)
+{
+       const char *name;
+       if (skip_prefix(k, "defopt.", &name) && !strcmp(name, defopt_key)) {
+               if (!v)
+                       return config_error_nonbool(k);
+               defopt_val = xstrdup(v);
+               return 0;
+       }
+       return 0;
+}
+
+char *defopt_lookup(const char *defopt)
+{
+       defopt_key = defopt;
+       defopt_val = NULL;
+       git_config(defopt_lookup_cb, NULL);
+       return defopt_val;
+}
diff --git a/git.c b/git.c
index 9c49519..4b556e1 100644
--- a/git.c
+++ b/git.c
@@ -223,6 +223,59 @@ static int handle_options(const char ***argv, int
*argc, int *envchanged)
        return (*argv) - orig_argv;
 }

+static int handle_defopt(int *argcp, const char ***argv)
+{      
+       int envchanged = 0, ret = 0, saved_errno = errno;
+       const char *subdir;
+       int count, option_count;
+       const char **new_argv;
+       const char *defopt_command;
+       char *defopt_string;
+       int unused_nongit;
+
+       subdir = setup_git_directory_gently(&unused_nongit);
+
+       defopt_command = (*argv)[0];
+       defopt_string = defopt_lookup(defopt_command);
+       if (defopt_string) {
+               
+               count = split_cmdline(defopt_string, &new_argv);
+               if (count < 0)
+                       return;
+               option_count = handle_options(&new_argv, &count, &envchanged);
+               
+               memmove(new_argv - option_count, new_argv,
+                               count * sizeof(char *));
+               new_argv -= option_count;
+
+               if (count < 1)
+                       return;
+
+               if (strcmp(defopt_command, new_argv[0]))
+                       return;
+
+               trace_argv_printf(new_argv,
+                                 "trace: defopt: %s =>",
+                                 defopt_command);
+
+               new_argv = xrealloc(new_argv, sizeof(char *) *
+                                   (count + *argcp));
+               /* insert after command name */
+               memcpy(new_argv + count, *argv + 1, sizeof(char *) * *argcp);
+
+               *argv = new_argv;
+               *argcp += count - 1;
+
+       }
+
+       if (subdir && chdir(subdir))
+               die_errno("Cannot change to '%s'", subdir);
+
+       errno = saved_errno;
+
+}
+
+
 static int handle_alias(int *argcp, const char ***argv)
 {
        int envchanged = 0, ret = 0, saved_errno = errno;
@@ -517,6 +570,9 @@ static void handle_builtin(int argc, const char **argv)
                argv[1] = argv[0];
                argv[0] = cmd = "help";
        }
+       
+       if(is_builtin(cmd) && argc == 1)
+               handle_defopt(&argc, &argv);

        for (i = 0; i < ARRAY_SIZE(commands); i++) {
                struct cmd_struct *p = commands+i;
-- 
        Signed-off-by: Yolande Amate <[email protected]>
1.7.10.4
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to