version 1.4, 2011/11/14 10:07:06 |
version 1.10, 2011/11/27 23:11:37 |
|
|
#ifndef APROPOS_H |
#ifndef APROPOS_H |
#define APROPOS_H |
#define APROPOS_H |
|
|
struct rec { |
struct res { |
|
char *type; /* file type: mdoc, man or cat */ |
char *file; /* file in file-system */ |
char *file; /* file in file-system */ |
char *cat; /* category (3p, 3, etc.) */ |
char *cat; /* category (3p, 3, etc.) */ |
char *title; /* title (FOO, etc.) */ |
char *title; /* title (FOO, etc.) */ |
|
|
char *desc; /* description (from Nd) */ |
char *desc; /* description (from Nd) */ |
unsigned int rec; /* record in index */ |
unsigned int rec; /* record in index */ |
/* |
/* |
* By the time the apropos_search() callback is called, these |
* The index volume. This indexes into the array of directories |
* are superfluous. |
* searched for manual page databases. |
* Maintain a binary tree for checking the uniqueness of `rec' |
|
* when adding elements to the results array. |
|
* Since the results array is dynamic, use offset in the array |
|
* instead of a pointer to the structure. |
|
*/ |
*/ |
int lhs; |
unsigned int volume; |
int rhs; |
|
}; |
}; |
|
|
struct opts { |
struct opts { |
|
|
|
|
struct expr; |
struct expr; |
|
|
void apropos_search(const struct opts *, |
int apropos_search(int, char **, const struct opts *, |
const struct expr *, void *, |
const struct expr *, size_t, void *, |
void (*)(struct rec *, size_t, void *)); |
void (*)(struct res *, size_t, void *)); |
|
struct expr *exprcomp(int, char *[], size_t *); |
struct expr *exprcomp(char *); |
|
void exprfree(struct expr *); |
void exprfree(struct expr *); |
|
struct expr *termcomp(int, char *[], size_t *); |
|
|
__END_DECLS |
__END_DECLS |
|
|