]> granicus.if.org Git - vim/commitdiff
updated for version 7.3.734 v7.3.734
authorBram Moolenaar <Bram@vim.org>
Wed, 28 Nov 2012 15:06:22 +0000 (16:06 +0100)
committerBram Moolenaar <Bram@vim.org>
Wed, 28 Nov 2012 15:06:22 +0000 (16:06 +0100)
Problem:    Cannot put help files in a sub-directory.
Solution:   Make :helptags work for sub-directories. (Charles Campbell)

src/ex_cmds.c
src/version.c

index 889ea62032ec6edc24dd9a14f139f9bed542fb28..0bef623c0e3e569b3f6c34b4214063893e71b903 100644 (file)
@@ -6344,10 +6344,10 @@ ex_helptags(eap)
     }
 
 #ifdef FEAT_MULTI_LANG
-    /* Get a list of all files in the directory. */
+    /* Get a list of all files in the help directory and in subdirectories. */
     STRCPY(NameBuff, dirname);
     add_pathsep(NameBuff);
-    STRCAT(NameBuff, "*");
+    STRCAT(NameBuff, "**");
     if (gen_expand_wildcards(1, &NameBuff, &filecount, &files,
                                                    EW_FILE|EW_SILENT) == FAIL
            || filecount == 0)
@@ -6436,8 +6436,8 @@ ex_helptags(eap)
 helptags_one(dir, ext, tagfname, add_help_tags)
     char_u     *dir;           /* doc directory */
     char_u     *ext;           /* suffix, ".txt", ".itx", ".frx", etc. */
-    char_u     *tagfname;      /* "tags" for English, "tags-fr" for French. */
-    int                add_help_tags;  /* add "help-tags" tag */
+    char_u     *tagfname;      /* "tags" for English, "tags-fr" for French. */
+    int                add_help_tags;  /* add "help-tags" tag */
 {
     FILE       *fd_tags;
     FILE       *fd;
@@ -6449,6 +6449,7 @@ helptags_one(dir, ext, tagfname, add_help_tags)
     char_u     *s;
     int                i;
     char_u     *fname;
+    int                dirlen;
 # ifdef FEAT_MBYTE
     int                utf8 = MAYBE;
     int                this_utf8;
@@ -6459,9 +6460,9 @@ helptags_one(dir, ext, tagfname, add_help_tags)
     /*
      * Find all *.txt files.
      */
+    dirlen = STRLEN(dir);
     STRCPY(NameBuff, dir);
-    add_pathsep(NameBuff);
-    STRCAT(NameBuff, "*");
+    STRCAT(NameBuff, "/**/*");
     STRCAT(NameBuff, ext);
     if (gen_expand_wildcards(1, &NameBuff, &filecount, &files,
                                                    EW_FILE|EW_SILENT) == FAIL
@@ -6522,7 +6523,7 @@ helptags_one(dir, ext, tagfname, add_help_tags)
            EMSG2(_("E153: Unable to open %s for reading"), files[fi]);
            continue;
        }
-       fname = gettail(files[fi]);
+       fname = files[fi] + dirlen + 1;
 
 # ifdef FEAT_MBYTE
        firstline = TRUE;
index 3582fbc99e0a8f569679ad80105dd6b3915bb5bc..87762a9781e0c41c3326962652737e38a93e8aa9 100644 (file)
@@ -725,6 +725,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    734,
 /**/
     733,
 /**/