|
|
1be407 |
diff -up man-db-2.6.3/src/manp.c.overrides man-db-2.6.3/src/manp.c
|
|
|
1be407 |
--- man-db-2.6.3/src/manp.c.overrides 2012-10-24 16:52:35.134486439 +0200
|
|
|
1be407 |
+++ man-db-2.6.3/src/manp.c 2012-10-24 16:59:28.300037133 +0200
|
|
|
1be407 |
@@ -51,6 +51,7 @@
|
|
|
1be407 |
#include <ctype.h>
|
|
|
1be407 |
#include <sys/types.h>
|
|
|
1be407 |
#include <sys/stat.h>
|
|
|
1be407 |
+#include <sys/param.h>
|
|
|
1be407 |
#include <assert.h>
|
|
|
1be407 |
#include <errno.h>
|
|
|
1be407 |
#include <dirent.h>
|
|
|
1be407 |
@@ -95,6 +96,9 @@ static struct list *namestore, *tailstor
|
|
|
1be407 |
#define MANPATH_MAP 0
|
|
|
1be407 |
#define MANDATORY 1
|
|
|
1be407 |
|
|
|
1be407 |
+/* Subdirectory of MANPATH entries searched for man pages before the directory itself. */
|
|
|
1be407 |
+#define OVERRIDES_DIR "/overrides"
|
|
|
1be407 |
+
|
|
|
1be407 |
/* DIRLIST list[MAXDIRS]; */
|
|
|
1be407 |
static char *tmplist[MAXDIRS];
|
|
|
1be407 |
|
|
|
1be407 |
@@ -933,6 +937,7 @@ char *get_manpath_from_path (const char
|
|
|
1be407 |
char **lp;
|
|
|
1be407 |
char *end;
|
|
|
1be407 |
char *manpathlist;
|
|
|
1be407 |
+ char overrides[MAXPATHLEN];
|
|
|
1be407 |
struct list *list;
|
|
|
1be407 |
|
|
|
1be407 |
tmppath = xstrdup (path);
|
|
|
1be407 |
@@ -960,6 +965,9 @@ char *get_manpath_from_path (const char
|
|
|
1be407 |
if (mandir_list) {
|
|
|
1be407 |
debug ("is in the config file\n");
|
|
|
1be407 |
while (mandir_list) {
|
|
|
1be407 |
+ strcpy(overrides, mandir_list->cont);
|
|
|
1be407 |
+ strcat(overrides, OVERRIDES_DIR);
|
|
|
1be407 |
+ add_dir_to_list (tmplist, overrides);
|
|
|
1be407 |
add_dir_to_list (tmplist, mandir_list->cont);
|
|
|
1be407 |
mandir_list = iterate_over_list
|
|
|
1be407 |
(mandir_list, p, MANPATH_MAP);
|
|
|
1be407 |
@@ -978,6 +986,9 @@ char *get_manpath_from_path (const char
|
|
|
1be407 |
"../share/man, or share/man "
|
|
|
1be407 |
"subdirectory\n");
|
|
|
1be407 |
|
|
|
1be407 |
+ strcpy(overrides, t);
|
|
|
1be407 |
+ strcat(overrides, OVERRIDES_DIR);
|
|
|
1be407 |
+ add_dir_to_list (tmplist, overrides);
|
|
|
1be407 |
add_dir_to_list (tmplist, t);
|
|
|
1be407 |
free (t);
|
|
|
1be407 |
} else
|
|
|
1be407 |
@@ -993,8 +1004,12 @@ char *get_manpath_from_path (const char
|
|
|
1be407 |
debug ("\nadding mandatory man directories\n\n");
|
|
|
1be407 |
|
|
|
1be407 |
for (list = namestore; list; list = list->next)
|
|
|
1be407 |
- if (list->flag == MANDATORY)
|
|
|
1be407 |
+ if (list->flag == MANDATORY) {
|
|
|
1be407 |
+ strcpy(overrides, list->key);
|
|
|
1be407 |
+ strcat(overrides, OVERRIDES_DIR);
|
|
|
1be407 |
+ add_dir_to_list (tmplist, overrides);
|
|
|
1be407 |
add_dir_to_list (tmplist, list->key);
|
|
|
1be407 |
+ }
|
|
|
1be407 |
}
|
|
|
1be407 |
|
|
|
1be407 |
len = 0;
|