Merge branch 'jc/rm-submodule-error-message'
authorJunio C Hamano <gitster@pobox.com>
Thu, 1 Aug 2013 18:57:25 +0000 (11:57 -0700)
committerJunio C Hamano <gitster@pobox.com>
Thu, 1 Aug 2013 18:57:25 +0000 (11:57 -0700)
Consolidate two messages phrased subtly differently without a good
reason.

* jc/rm-submodule-error-message:
builtin/rm.c: consolidate error reporting for removing submodules

1  2 
builtin/rm.c
diff --combined builtin/rm.c
index 18916e022a2189a477927f0f351f63dd3b6fe695,694568a0e5058c7d3bdad852238f740069a085c5..0df0b4d942c09769ff42539f6aaf83dcc31e20fb
@@@ -51,13 -51,27 +51,28 @@@ static void print_error_files(struct st
                        strbuf_addf(&err_msg,
                                    "\n    %s",
                                    files_list->items[i].string);
 -              strbuf_addstr(&err_msg, hints_msg);
 +              if (advice_rm_hints)
 +                      strbuf_addstr(&err_msg, hints_msg);
                *errs = error("%s", err_msg.buf);
                strbuf_release(&err_msg);
        }
  }
  
+ static void error_removing_concrete_submodules(struct string_list *files, int *errs)
+ {
+       print_error_files(files,
+                         Q_("the following submodule (or one of its nested "
+                            "submodules)\n"
+                            "uses a .git directory:",
+                            "the following submodules (or one of its nested "
+                            "submodules)\n"
+                            "use a .git directory:", files->nr),
+                         _("\n(use 'rm -rf' if you really want to remove "
+                           "it including all of its history)"),
+                         errs);
+       string_list_clear(files, 0);
+ }
  static int check_submodules_use_gitfiles(void)
  {
        int i;
@@@ -67,7 -81,7 +82,7 @@@
        for (i = 0; i < list.nr; i++) {
                const char *name = list.entry[i].name;
                int pos;
 -              struct cache_entry *ce;
 +              const struct cache_entry *ce;
                struct stat st;
  
                pos = cache_name_pos(name, strlen(name));
                if (!submodule_uses_gitfile(name))
                        string_list_append(&files, name);
        }
-       print_error_files(&files,
-                         Q_("the following submodule (or one of its nested "
-                            "submodules)\n uses a .git directory:",
-                            "the following submodules (or one of its nested "
-                            "submodules)\n use a .git directory:",
-                            files.nr),
-                         _("\n(use 'rm -rf' if you really want to remove "
-                           "it including all of its history)"),
-                         &errs);
-       string_list_clear(&files, 0);
+       error_removing_concrete_submodules(&files, &errs);
  
        return errs;
  }
@@@ -120,7 -126,7 +127,7 @@@ static int check_local_mod(unsigned cha
        for (i = 0; i < list.nr; i++) {
                struct stat st;
                int pos;
 -              struct cache_entry *ce;
 +              const struct cache_entry *ce;
                const char *name = list.entry[i].name;
                unsigned char sha1[20];
                unsigned mode;
                            " or -f to force removal)"),
                          &errs);
        string_list_clear(&files_cached, 0);
-       print_error_files(&files_submodule,
-                         Q_("the following submodule (or one of its nested "
-                            "submodule)\nuses a .git directory:",
-                            "the following submodules (or one of its nested "
-                            "submodule)\nuse a .git directory:",
-                            files_submodule.nr),
-                         _("\n(use 'rm -rf' if you really "
-                           "want to remove it including all "
-                           "of its history)"),
-                         &errs);
-       string_list_clear(&files_submodule, 0);
+       error_removing_concrete_submodules(&files_submodule, &errs);
        print_error_files(&files_local,
                          Q_("the following file has local modifications:",
                             "the following files have local modifications:",
@@@ -321,7 -319,7 +320,7 @@@ int cmd_rm(int argc, const char **argv
        seen = xcalloc(i, 1);
  
        for (i = 0; i < active_nr; i++) {
 -              struct cache_entry *ce = active_cache[i];
 +              const struct cache_entry *ce = active_cache[i];
                if (!match_pathspec(pathspec, ce->name, ce_namelen(ce), 0, seen))
                        continue;
                ALLOC_GROW(list.entry, list.nr + 1, list.alloc);